mirror of
https://git.mirrors.martin98.com/https://github.com/Ultimaker/Cura
synced 2025-04-16 18:59:39 +08:00
189 lines
6.0 KiB
QML
189 lines
6.0 KiB
QML
// Copyright (c) 2018 Ultimaker B.V.
|
|
// Toolbox is released under the terms of the LGPLv3 or higher.
|
|
|
|
import QtQuick 2.10
|
|
import QtQuick.Controls 1.4
|
|
import QtQuick.Controls.Styles 1.4
|
|
import UM 1.5 as UM
|
|
|
|
import Cura 1.1 as Cura
|
|
|
|
import "../components"
|
|
|
|
Item
|
|
{
|
|
id: page
|
|
property var details: base.selection || {}
|
|
anchors.fill: parent
|
|
ToolboxBackColumn
|
|
{
|
|
id: sidebar
|
|
}
|
|
Item
|
|
{
|
|
id: header
|
|
anchors
|
|
{
|
|
left: sidebar.right
|
|
right: parent.right
|
|
rightMargin: UM.Theme.getSize("wide_margin").width
|
|
}
|
|
height: childrenRect.height + 3 * UM.Theme.getSize("default_margin").width
|
|
Rectangle
|
|
{
|
|
id: thumbnail
|
|
width: UM.Theme.getSize("toolbox_thumbnail_medium").width
|
|
height: UM.Theme.getSize("toolbox_thumbnail_medium").height
|
|
anchors
|
|
{
|
|
top: parent.top
|
|
left: parent.left
|
|
leftMargin: UM.Theme.getSize("wide_margin").width
|
|
topMargin: UM.Theme.getSize("wide_margin").height
|
|
}
|
|
color: UM.Theme.getColor("main_background")
|
|
Image
|
|
{
|
|
anchors.fill: parent
|
|
fillMode: Image.PreserveAspectFit
|
|
source: details === null ? "" : (details.icon_url || "../../images/placeholder.svg")
|
|
mipmap: true
|
|
height: UM.Theme.getSize("toolbox_thumbnail_large").height - 4 * UM.Theme.getSize("default_margin").height
|
|
width: UM.Theme.getSize("toolbox_thumbnail_large").height - 4 * UM.Theme.getSize("default_margin").height
|
|
sourceSize.height: height
|
|
sourceSize.width: width
|
|
}
|
|
}
|
|
|
|
Label
|
|
{
|
|
id: title
|
|
anchors
|
|
{
|
|
top: thumbnail.top
|
|
left: thumbnail.right
|
|
leftMargin: UM.Theme.getSize("default_margin").width
|
|
}
|
|
text: details === null ? "" : (details.name || "")
|
|
font: UM.Theme.getFont("large_bold")
|
|
color: UM.Theme.getColor("text")
|
|
width: contentWidth
|
|
height: contentHeight
|
|
renderType: Text.NativeRendering
|
|
}
|
|
|
|
Column
|
|
{
|
|
id: properties
|
|
anchors
|
|
{
|
|
top: title.bottom
|
|
left: title.left
|
|
topMargin: UM.Theme.getSize("default_margin").height
|
|
}
|
|
spacing: Math.floor(UM.Theme.getSize("narrow_margin").height)
|
|
width: childrenRect.width
|
|
height: childrenRect.height
|
|
Label
|
|
{
|
|
text: catalog.i18nc("@label", "Version") + ":"
|
|
font: UM.Theme.getFont("default")
|
|
color: UM.Theme.getColor("text_medium")
|
|
renderType: Text.NativeRendering
|
|
}
|
|
Label
|
|
{
|
|
text: catalog.i18nc("@label", "Last updated") + ":"
|
|
font: UM.Theme.getFont("default")
|
|
color: UM.Theme.getColor("text_medium")
|
|
renderType: Text.NativeRendering
|
|
}
|
|
Label
|
|
{
|
|
text: catalog.i18nc("@label", "Brand") + ":"
|
|
font: UM.Theme.getFont("default")
|
|
color: UM.Theme.getColor("text_medium")
|
|
renderType: Text.NativeRendering
|
|
}
|
|
Label
|
|
{
|
|
text: catalog.i18nc("@label", "Downloads") + ":"
|
|
font: UM.Theme.getFont("default")
|
|
color: UM.Theme.getColor("text_medium")
|
|
renderType: Text.NativeRendering
|
|
}
|
|
}
|
|
Column
|
|
{
|
|
id: values
|
|
anchors
|
|
{
|
|
top: title.bottom
|
|
left: properties.right
|
|
leftMargin: UM.Theme.getSize("default_margin").width
|
|
topMargin: UM.Theme.getSize("default_margin").height
|
|
}
|
|
spacing: Math.floor(UM.Theme.getSize("narrow_margin").height)
|
|
height: childrenRect.height
|
|
Label
|
|
{
|
|
text: details === null ? "" : (details.version || catalog.i18nc("@label", "Unknown"))
|
|
font: UM.Theme.getFont("default")
|
|
color: UM.Theme.getColor("text")
|
|
renderType: Text.NativeRendering
|
|
}
|
|
Label
|
|
{
|
|
text:
|
|
{
|
|
if (details === null)
|
|
{
|
|
return ""
|
|
}
|
|
var date = new Date(details.last_updated)
|
|
return date.toLocaleString(UM.Preferences.getValue("general/language"))
|
|
}
|
|
font: UM.Theme.getFont("default")
|
|
color: UM.Theme.getColor("text")
|
|
renderType: Text.NativeRendering
|
|
}
|
|
Label
|
|
{
|
|
text:
|
|
{
|
|
if (details === null)
|
|
{
|
|
return ""
|
|
}
|
|
else
|
|
{
|
|
return "<a href=\"" + details.website + "\">" + details.author_name + "</a>"
|
|
}
|
|
}
|
|
font: UM.Theme.getFont("default")
|
|
color: UM.Theme.getColor("text")
|
|
linkColor: UM.Theme.getColor("text_link")
|
|
onLinkActivated: UM.UrlUtil.openUrl(link, ["http", "https"])
|
|
renderType: Text.NativeRendering
|
|
}
|
|
Label
|
|
{
|
|
text: details === null ? "" : (details.download_count || catalog.i18nc("@label", "Unknown"))
|
|
font: UM.Theme.getFont("default")
|
|
color: UM.Theme.getColor("text")
|
|
renderType: Text.NativeRendering
|
|
}
|
|
}
|
|
}
|
|
ToolboxDetailList
|
|
{
|
|
anchors
|
|
{
|
|
top: header.bottom
|
|
bottom: page.bottom
|
|
left: header.left
|
|
right: page.right
|
|
}
|
|
}
|
|
}
|