mirror of
https://git.mirrors.martin98.com/https://github.com/Ultimaker/Cura
synced 2025-04-29 23:34:32 +08:00
108 lines
3.2 KiB
QML
108 lines
3.2 KiB
QML
// Copyright (c) 2018 Ultimaker B.V.
|
|
// Toolbox is released under the terms of the LGPLv3 or higher.
|
|
|
|
import QtQuick 2.2
|
|
import QtQuick.Dialogs 1.1
|
|
import QtQuick.Window 2.2
|
|
import QtQuick.Controls 1.4
|
|
import QtQuick.Controls.Styles 1.4
|
|
import QtQuick.Layouts 1.3
|
|
import UM 1.1 as UM
|
|
|
|
Item
|
|
{
|
|
id: base
|
|
height: childrenRect.height
|
|
Layout.alignment: Qt.AlignTop | Qt.AlignLeft
|
|
Rectangle
|
|
{
|
|
id: highlight
|
|
anchors.fill: parent
|
|
opacity: 0.0
|
|
color: UM.Theme.getColor("primary")
|
|
}
|
|
Row
|
|
{
|
|
width: parent.width
|
|
height: childrenRect.height
|
|
spacing: Math.floor(UM.Theme.getSize("base_unit").width / 2)
|
|
Rectangle
|
|
{
|
|
id: thumbnail
|
|
width: UM.Theme.getSize("toolbox_thumbnail_small").width
|
|
height: UM.Theme.getSize("toolbox_thumbnail_small").height
|
|
color: "white"
|
|
border.width: UM.Theme.getSize("default_lining").width
|
|
border.color: UM.Theme.getColor("lining")
|
|
Image {
|
|
anchors.centerIn: parent
|
|
width: UM.Theme.getSize("toolbox_thumbnail_small").width - 26
|
|
height: UM.Theme.getSize("toolbox_thumbnail_small").height - 26
|
|
fillMode: Image.PreserveAspectFit
|
|
source: model.icon_url || "../images/logobot.svg"
|
|
}
|
|
}
|
|
Column
|
|
{
|
|
width: parent.width - thumbnail.width - parent.spacing
|
|
spacing: Math.floor(UM.Theme.getSize("base_unit").width / 2)
|
|
Label
|
|
{
|
|
id: name
|
|
text: model.name
|
|
width: parent.width
|
|
wrapMode: Text.WordWrap
|
|
color: UM.Theme.getColor("text")
|
|
font: UM.Theme.getFont("default_bold")
|
|
}
|
|
Label
|
|
{
|
|
id: info
|
|
text: {
|
|
if (model.description.length > 50)
|
|
{
|
|
return model.description.substring(0, 50) + "..."
|
|
}
|
|
return model.description
|
|
}
|
|
width: parent.width
|
|
wrapMode: Text.WordWrap
|
|
color: UM.Theme.getColor("text_medium")
|
|
font: UM.Theme.getFont("very_small")
|
|
}
|
|
}
|
|
}
|
|
MouseArea
|
|
{
|
|
anchors.fill: parent
|
|
hoverEnabled: true
|
|
onEntered:
|
|
{
|
|
thumbnail.border.color = UM.Theme.getColor("primary")
|
|
highlight.opacity = 0.1
|
|
}
|
|
onExited:
|
|
{
|
|
thumbnail.border.color = UM.Theme.getColor("text")
|
|
highlight.opacity = 0.0
|
|
}
|
|
onClicked:
|
|
{
|
|
if ( toolbox.viewCategory == "material" )
|
|
{
|
|
toolbox.viewSelection = model.name
|
|
toolbox.viewPage = "author"
|
|
toolbox.filterAuthors("name", model.name)
|
|
toolbox.filterPackages("author_name", model.name)
|
|
}
|
|
else
|
|
{
|
|
toolbox.viewSelection = model.id
|
|
toolbox.viewPage = "detail"
|
|
toolbox.filterAuthors("name", model.author_name)
|
|
toolbox.filterPackages("id", model.id)
|
|
}
|
|
}
|
|
}
|
|
}
|