123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305 |
- // 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
- Rectangle
- {
- property var packageData
- width: parent ? parent.width - UM.Theme.getSize("default_margin").width : 0
- height: UM.Theme.getSize("card").height
- color: UM.Theme.getColor("main_background")
- radius: UM.Theme.getSize("default_radius").width
- states:
- [
- State
- {
- name: "Folded"
- when: true // TODO
- PropertyChanges
- {
- target: descriptionArea
- visible: true
- }
- },
- State
- {
- name: "Header"
- when: false // TODO
- PropertyChanges
- {
- target: descriptionArea
- visible: false
- }
- }
- ]
- Image //Separate column for icon on the left.
- {
- id: packageItem
- anchors
- {
- top: parent.top
- left: parent.left
- margins: UM.Theme.getSize("default_margin").width
- }
- width: UM.Theme.getSize("card_icon").width
- height: width
- source: packageData.iconUrl != "" ? packageData.iconUrl : "../images/placeholder.svg"
- }
- RowLayout //Title row.
- {
- id: titleBar
- anchors
- {
- left: packageItem.right
- right: parent.right
- top: parent.top
- topMargin: UM.Theme.getSize("default_margin").height
- leftMargin: UM.Theme.getSize("default_margin").width
- rightMargin:UM.Theme.getSize("thick_margin").width
- }
- Label
- {
- text: packageData.displayName
- font: UM.Theme.getFont("large_bold")
- color: UM.Theme.getColor("text")
- verticalAlignment: Text.AlignTop
- }
- Control
- {
- Layout.preferredWidth: UM.Theme.getSize("card_tiny_icon").width
- Layout.preferredHeight: UM.Theme.getSize("card_tiny_icon").height
- enabled: packageData.isVerified
- visible: packageData.isVerified
- Cura.ToolTip
- {
- tooltipText: catalog.i18nc("@info", "Verified")
- visible: parent.hovered
- }
- Rectangle
- {
- anchors.fill: parent
- color: UM.Theme.getColor("action_button_hovered")
- radius: width
- UM.RecolorImage
- {
- anchors.fill: parent
- color: UM.Theme.getColor("primary")
- source: UM.Theme.getIcon("CheckCircle")
- }
- }
- //NOTE: Can we link to something here? (Probably a static link explaining what verified is):
- // onClicked: Qt.openUrlExternally( XXXXXX )
- }
- Control
- {
- Layout.preferredWidth: UM.Theme.getSize("card_tiny_icon").width
- Layout.preferredHeight: UM.Theme.getSize("card_tiny_icon").height
- Layout.alignment: Qt.AlignCenter
- enabled: false // remove!
- visible: false // replace packageInfo.XXXXXX
- // TODO: waiting for materials card implementation
- Cura.ToolTip
- {
- tooltipText: "" // TODO
- visible: parent.hovered
- }
- UM.RecolorImage
- {
- anchors.fill: parent
- color: UM.Theme.getColor("primary")
- source: UM.Theme.getIcon("CheckCircle") // TODO
- }
- // onClicked: Qt.openUrlExternally( XXXXXX ) // TODO
- }
- Label
- {
- id: packageVersionLabel
- text: packageData.packageVersion
- font: UM.Theme.getFont("default")
- color: UM.Theme.getColor("text")
- Layout.fillWidth: true
- }
- UM.SimpleButton
- {
- id: externalLinkButton
- Layout.preferredWidth: UM.Theme.getSize("card_tiny_icon").width
- Layout.preferredHeight: UM.Theme.getSize("card_tiny_icon").height
- Layout.alignment: Qt.AlignTop
- iconSource: UM.Theme.getIcon("LinkExternal")
- hoverColor: UM.Theme.getColor("text_link")
- onClicked: Qt.openUrlExternally(packageData.packageInfoUrl)
- }
- }
- Item
- {
- id: descriptionArea
- height: descriptionLabel.height
- anchors
- {
- top: titleBar.bottom
- left: packageItem.right
- right: parent.right
- rightMargin: UM.Theme.getSize("default_margin").width
- leftMargin: UM.Theme.getSize("default_margin").width
- }
- Label
- {
- id: descriptionLabel
- width: parent.width
- property real lastLineWidth: 0; //Store the width of the last line, to properly position the elision.
- text: packageData.description
- font: UM.Theme.getFont("medium")
- color: UM.Theme.getColor("text")
- maximumLineCount: 2
- wrapMode: Text.Wrap
- elide: Text.ElideRight
- onLineLaidOut:
- {
- if(truncated && line.isLast)
- {
- let max_line_width = parent.width - readMoreButton.width - fontMetrics.advanceWidth("… ") - 2 * UM.Theme.getSize("default_margin").width;
- if(line.implicitWidth > max_line_width)
- {
- line.width = max_line_width;
- }
- else
- {
- line.width = line.implicitWidth - fontMetrics.advanceWidth("…"); //Truncate the ellipsis. We're adding this ourselves.
- }
- descriptionLabel.lastLineWidth = line.implicitWidth;
- }
- }
- }
- Label
- {
- id: tripleDotLabel
- anchors.left: parent.left
- anchors.leftMargin: descriptionLabel.lastLineWidth
- anchors.bottom: readMoreButton.bottom
- text: "… "
- font: descriptionLabel.font
- color: descriptionLabel.color
- visible: descriptionLabel.truncated
- }
- Cura.TertiaryButton
- {
- id: readMoreButton
- anchors.left: tripleDotLabel.right
- anchors.bottom: parent.bottom
- height: fontMetrics.height //Height of a single line.
- text: catalog.i18nc("@info", "Read more")
- iconSource: UM.Theme.getIcon("LinkExternal")
- visible: descriptionLabel.truncated
- enabled: visible
- leftPadding: UM.Theme.getSize("default_margin").width
- rightPadding: UM.Theme.getSize("wide_margin").width
- textFont: descriptionLabel.font
- isIconOnRightSide: true
- // NOTE: Is this the right URL for this action?
- onClicked: Qt.openUrlExternally(packageData.packageInfoUrl)
- }
- }
- RowLayout //Author and action buttons.
- {
- id: authorAndACtionButton
- width: parent.width
- anchors
- {
- bottom: parent.bottom
- left: packageItem.right
- margins: UM.Theme.getSize("default_margin").height
- }
- spacing: UM.Theme.getSize("narrow_margin").width
- Label
- {
- id: authorBy
- Layout.alignment: Qt.AlignTop
- text: catalog.i18nc("@label", "By")
- font: UM.Theme.getFont("default")
- color: UM.Theme.getColor("text")
- }
- Cura.TertiaryButton
- {
- Layout.fillWidth: true
- Layout.preferredHeight: authorBy.height
- Layout.alignment: Qt.AlignTop
- text: packageData.authorName
- textFont: UM.Theme.getFont("default_bold")
- textColor: UM.Theme.getColor("text") // override normal link color
- leftPadding: 0
- rightPadding: 0
- iconSource: UM.Theme.getIcon("LinkExternal")
- isIconOnRightSide: true
- onClicked: Qt.openUrlExternally(packageData.authorInfoUrl)
- }
- Cura.SecondaryButton
- {
- id: disableButton
- Layout.alignment: Qt.AlignTop
- text: catalog.i18nc("@button", "Disable")
- visible: false // not functional right now, also only when unfolding and required
- }
- Cura.SecondaryButton
- {
- id: uninstallButton
- Layout.alignment: Qt.AlignTop
- text: catalog.i18nc("@button", "Uninstall")
- visible: false // not functional right now, also only when unfolding and required
- }
- Cura.PrimaryButton
- {
- id: installButton
- Layout.alignment: Qt.AlignTop
- text: catalog.i18nc("@button", "Update") // OR Download, if new!
- visible: false // not functional right now, also only when unfolding and required
- }
- }
- FontMetrics
- {
- id: fontMetrics
- font: UM.Theme.getFont("medium")
- }
- }
|