mirror of
https://github.com/Ultimaker/Cura.git
synced 2025-07-06 22:47:29 -06:00
Re-use Marketplace
Component in the InstallMissingPackagesDialog
CURA-6990
This commit is contained in:
parent
2f22002fd5
commit
bee4da6368
2 changed files with 12 additions and 145 deletions
|
@ -9,150 +9,11 @@ import QtQuick.Window 2.2
|
||||||
import UM 1.5 as UM
|
import UM 1.5 as UM
|
||||||
import Cura 1.6 as Cura
|
import Cura 1.6 as Cura
|
||||||
|
|
||||||
Window
|
Marketplace
|
||||||
{
|
{
|
||||||
id: marketplaceDialog
|
|
||||||
|
|
||||||
property variant catalog: UM.I18nCatalog { name: "cura" }
|
|
||||||
|
|
||||||
signal searchStringChanged(string new_search)
|
|
||||||
|
|
||||||
minimumWidth: UM.Theme.getSize("modal_window_minimum").width
|
|
||||||
minimumHeight: UM.Theme.getSize("modal_window_minimum").height
|
|
||||||
width: minimumWidth
|
|
||||||
height: minimumHeight
|
|
||||||
|
|
||||||
onVisibleChanged:
|
|
||||||
{
|
|
||||||
while(contextStack.depth > 1)
|
|
||||||
{
|
|
||||||
contextStack.pop(); //Do NOT use the StackView.Immediate transition here, since it causes the window to stay empty. Seemingly a Qt bug: https://bugreports.qt.io/browse/QTBUG-60670?
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Connections
|
|
||||||
{
|
|
||||||
target: Cura.API.account
|
|
||||||
function onLoginStateChanged()
|
|
||||||
{
|
|
||||||
close();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
title: catalog.i18nc("@title", "Install missing Materials")
|
|
||||||
modality: Qt.ApplicationModal
|
modality: Qt.ApplicationModal
|
||||||
|
title: catalog.i18nc("@title", "Install missing Materials")
|
||||||
// Background color
|
pageContentsSource: "MissingPackages.qml"
|
||||||
Rectangle
|
showSearchHeader: false
|
||||||
{
|
showOnboadBanner: false
|
||||||
anchors.fill: parent
|
|
||||||
color: UM.Theme.getColor("main_background")
|
|
||||||
}
|
|
||||||
//The Marketplace can have a page in front of everything with package details. The stack view controls its visibility.
|
|
||||||
StackView
|
|
||||||
{
|
|
||||||
id: contextStack
|
|
||||||
anchors.fill: parent
|
|
||||||
|
|
||||||
initialItem: packageBrowse
|
|
||||||
|
|
||||||
ColumnLayout
|
|
||||||
{
|
|
||||||
id: packageBrowse
|
|
||||||
|
|
||||||
spacing: UM.Theme.getSize("narrow_margin").height
|
|
||||||
|
|
||||||
// Page title.
|
|
||||||
Item
|
|
||||||
{
|
|
||||||
Layout.preferredWidth: parent.width
|
|
||||||
Layout.preferredHeight: childrenRect.height + UM.Theme.getSize("default_margin").height
|
|
||||||
|
|
||||||
UM.Label
|
|
||||||
{
|
|
||||||
id: pageTitle
|
|
||||||
anchors
|
|
||||||
{
|
|
||||||
left: parent.left
|
|
||||||
leftMargin: UM.Theme.getSize("default_margin").width
|
|
||||||
right: parent.right
|
|
||||||
rightMargin: UM.Theme.getSize("default_margin").width
|
|
||||||
bottom: parent.bottom
|
|
||||||
}
|
|
||||||
|
|
||||||
font: UM.Theme.getFont("large")
|
|
||||||
text: content.item ? content.item.pageTitle: catalog.i18nc("@title", "Loading...")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Page contents.
|
|
||||||
Rectangle
|
|
||||||
{
|
|
||||||
Layout.preferredWidth: parent.width
|
|
||||||
Layout.fillHeight: true
|
|
||||||
color: UM.Theme.getColor("detail_background")
|
|
||||||
|
|
||||||
// Page contents.
|
|
||||||
Loader
|
|
||||||
{
|
|
||||||
id: content
|
|
||||||
anchors.fill: parent
|
|
||||||
anchors.margins: UM.Theme.getSize("default_margin").width
|
|
||||||
source: "MissingPackages.qml"
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Rectangle
|
|
||||||
{
|
|
||||||
height: quitButton.height + 2 * UM.Theme.getSize("default_margin").width
|
|
||||||
color: UM.Theme.getColor("primary")
|
|
||||||
visible: manager.showRestartNotification
|
|
||||||
anchors
|
|
||||||
{
|
|
||||||
left: parent.left
|
|
||||||
right: parent.right
|
|
||||||
bottom: parent.bottom
|
|
||||||
}
|
|
||||||
|
|
||||||
RowLayout
|
|
||||||
{
|
|
||||||
anchors
|
|
||||||
{
|
|
||||||
left: parent.left
|
|
||||||
right: parent.right
|
|
||||||
verticalCenter: parent.verticalCenter
|
|
||||||
margins: UM.Theme.getSize("default_margin").width
|
|
||||||
}
|
|
||||||
spacing: UM.Theme.getSize("default_margin").width
|
|
||||||
UM.ColorImage
|
|
||||||
{
|
|
||||||
id: bannerIcon
|
|
||||||
source: UM.Theme.getIcon("Plugin")
|
|
||||||
|
|
||||||
color: UM.Theme.getColor("primary_button_text")
|
|
||||||
implicitWidth: UM.Theme.getSize("banner_icon_size").width
|
|
||||||
implicitHeight: UM.Theme.getSize("banner_icon_size").height
|
|
||||||
}
|
|
||||||
Text
|
|
||||||
{
|
|
||||||
color: UM.Theme.getColor("primary_button_text")
|
|
||||||
text: catalog.i18nc("@button", "In order to use the package you will need to restart Cura")
|
|
||||||
font: UM.Theme.getFont("default")
|
|
||||||
renderType: Text.NativeRendering
|
|
||||||
Layout.fillWidth: true
|
|
||||||
}
|
|
||||||
Cura.SecondaryButton
|
|
||||||
{
|
|
||||||
id: quitButton
|
|
||||||
text: catalog.i18nc("@info:button, %1 is the application name", "Quit %1").arg(CuraApplication.applicationDisplayName)
|
|
||||||
onClicked:
|
|
||||||
{
|
|
||||||
marketplaceDialog.hide();
|
|
||||||
CuraApplication.closeApplication();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -16,6 +16,10 @@ Window
|
||||||
|
|
||||||
signal searchStringChanged(string new_search)
|
signal searchStringChanged(string new_search)
|
||||||
|
|
||||||
|
property alias showOnboadBanner: onBoardBanner.visible
|
||||||
|
property alias showSearchHeader: searchHeader.visible
|
||||||
|
property alias pageContentsSource: content.source
|
||||||
|
|
||||||
minimumWidth: UM.Theme.getSize("modal_window_minimum").width
|
minimumWidth: UM.Theme.getSize("modal_window_minimum").width
|
||||||
minimumHeight: UM.Theme.getSize("modal_window_minimum").height
|
minimumHeight: UM.Theme.getSize("modal_window_minimum").height
|
||||||
width: minimumWidth
|
width: minimumWidth
|
||||||
|
@ -86,6 +90,7 @@ Window
|
||||||
|
|
||||||
OnboardBanner
|
OnboardBanner
|
||||||
{
|
{
|
||||||
|
id: onBoardBanner
|
||||||
visible: content.item && content.item.bannerVisible
|
visible: content.item && content.item.bannerVisible
|
||||||
text: content.item && content.item.bannerText
|
text: content.item && content.item.bannerText
|
||||||
icon: content.item && content.item.bannerIcon
|
icon: content.item && content.item.bannerIcon
|
||||||
|
@ -100,6 +105,7 @@ Window
|
||||||
// Search & Top-Level Tabs
|
// Search & Top-Level Tabs
|
||||||
Item
|
Item
|
||||||
{
|
{
|
||||||
|
id: searchHeader
|
||||||
implicitHeight: childrenRect.height
|
implicitHeight: childrenRect.height
|
||||||
implicitWidth: parent.width - 2 * UM.Theme.getSize("default_margin").width
|
implicitWidth: parent.width - 2 * UM.Theme.getSize("default_margin").width
|
||||||
Layout.alignment: Qt.AlignHCenter
|
Layout.alignment: Qt.AlignHCenter
|
||||||
|
@ -186,7 +192,7 @@ Window
|
||||||
{
|
{
|
||||||
text: catalog.i18nc("@info", "Search in the browser")
|
text: catalog.i18nc("@info", "Search in the browser")
|
||||||
iconSource: UM.Theme.getIcon("LinkExternal")
|
iconSource: UM.Theme.getIcon("LinkExternal")
|
||||||
visible: pageSelectionTabBar.currentItem.hasSearch
|
visible: pageSelectionTabBar.currentItem.hasSearch && searchHeader.visible
|
||||||
isIconOnRightSide: true
|
isIconOnRightSide: true
|
||||||
height: fontMetrics.height
|
height: fontMetrics.height
|
||||||
textFont: fontMetrics.font
|
textFont: fontMetrics.font
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue