123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121 |
- // 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.1 as UM
- Item
- {
- height: UM.Theme.getSize("toolbox_installed_tile").height
- width: parent.width
- property bool isEnabled: true
- Rectangle
- {
- color: UM.Theme.getColor("lining")
- width: parent.width
- height: Math.floor(UM.Theme.getSize("default_lining").height)
- anchors.bottom: parent.bottom
- }
- Row
- {
- id: tileRow
- height: parent.height
- width: parent.width
- spacing: UM.Theme.getSize("default_margin").width
- topPadding: UM.Theme.getSize("default_margin").height
- CheckBox
- {
- id: disableButton
- anchors.verticalCenter: pluginInfo.verticalCenter
- checked: isEnabled
- visible: model.type == "plugin"
- width: visible ? UM.Theme.getSize("checkbox").width : 0
- enabled: !toolbox.isDownloading
- style: UM.Theme.styles.checkbox
- onClicked: toolbox.isEnabled(model.id) ? toolbox.disable(model.id) : toolbox.enable(model.id)
- }
- Column
- {
- id: pluginInfo
- topPadding: Math.floor(UM.Theme.getSize("default_margin").height / 2)
- property var color: model.type === "plugin" && !isEnabled ? UM.Theme.getColor("lining") : UM.Theme.getColor("text")
- width: Math.floor(tileRow.width - (authorInfo.width + pluginActions.width + 2 * tileRow.spacing + ((disableButton.visible) ? disableButton.width + tileRow.spacing : 0)))
- Label
- {
- text: model.name
- width: parent.width
- height: Math.floor(UM.Theme.getSize("toolbox_property_label").height)
- wrapMode: Text.WordWrap
- font: UM.Theme.getFont("large_bold")
- color: pluginInfo.color
- renderType: Text.NativeRendering
- }
- Label
- {
- text: model.description
- font: UM.Theme.getFont("default")
- maximumLineCount: 3
- elide: Text.ElideRight
- width: parent.width
- wrapMode: Text.WordWrap
- color: pluginInfo.color
- renderType: Text.NativeRendering
- }
- }
- Column
- {
- id: authorInfo
- width: Math.floor(UM.Theme.getSize("toolbox_action_button").width * 1.25)
- Label
- {
- text:
- {
- if (model.author_email)
- {
- return "<a href=\"mailto:" + model.author_email + "?Subject=Cura: " + model.name + "\">" + model.author_name + "</a>"
- }
- else
- {
- return model.author_name
- }
- }
- font: UM.Theme.getFont("medium")
- width: parent.width
- height: Math.floor(UM.Theme.getSize("toolbox_property_label").height)
- wrapMode: Text.WordWrap
- verticalAlignment: Text.AlignVCenter
- horizontalAlignment: Text.AlignLeft
- onLinkActivated: Qt.openUrlExternally("mailto:" + model.author_email + "?Subject=Cura: " + model.name + " Plugin")
- color: model.enabled ? UM.Theme.getColor("text") : UM.Theme.getColor("lining")
- linkColor: UM.Theme.getColor("text_link")
- renderType: Text.NativeRendering
- }
- Label
- {
- text: model.version
- font: UM.Theme.getFont("default")
- width: parent.width
- height: UM.Theme.getSize("toolbox_property_label").height
- color: UM.Theme.getColor("text")
- verticalAlignment: Text.AlignVCenter
- horizontalAlignment: Text.AlignLeft
- renderType: Text.NativeRendering
- }
- }
- ToolboxInstalledTileActions
- {
- id: pluginActions
- }
- Connections
- {
- target: toolbox
- onEnabledChanged: isEnabled = toolbox.isEnabled(model.id)
- }
- }
- }
|