2020-10-27 16:53:22 -04:00
|
|
|
import QtQuick 2.13
|
2021-08-17 19:03:03 +02:00
|
|
|
|
|
|
|
import StatusQ.Components 0.1 as StatusQ
|
|
|
|
import StatusQ.Core.Theme 0.1
|
|
|
|
|
2020-10-27 16:53:22 -04:00
|
|
|
import "../../../../shared"
|
|
|
|
import "../../../../shared/status"
|
2021-09-28 18:04:06 +03:00
|
|
|
|
|
|
|
import utils 1.0
|
2020-10-27 16:53:22 -04:00
|
|
|
|
|
|
|
Item {
|
2021-08-17 19:03:03 +02:00
|
|
|
property url webUrl
|
2020-10-30 11:46:47 -04:00
|
|
|
property url source
|
2020-10-27 16:53:22 -04:00
|
|
|
property string text
|
2020-10-29 16:07:52 -04:00
|
|
|
signal clicked(mouse: var)
|
|
|
|
signal rightClicked(mouse: var)
|
2020-10-27 16:53:22 -04:00
|
|
|
|
|
|
|
id: root
|
|
|
|
width: 74
|
2021-08-17 19:03:03 +02:00
|
|
|
height: 48 + Style.current.halfPadding
|
2020-10-27 16:53:22 -04:00
|
|
|
|
|
|
|
SVGImage {
|
|
|
|
id: bookmarkImage
|
|
|
|
width: 48
|
|
|
|
height: 48
|
2021-08-17 19:03:03 +02:00
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
2021-09-28 18:04:06 +03:00
|
|
|
source: !!root.source && !!root.source.toString() ? root.source : Style.svg("compassActive")
|
2021-08-17 19:03:03 +02:00
|
|
|
visible: root.source && root.source.toString()
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusQ.StatusRoundIcon {
|
|
|
|
id: addButton
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
icon.name: "add"
|
|
|
|
icon.color: Theme.palette.baseColor1
|
|
|
|
color: Theme.palette.baseColor2
|
|
|
|
visible: !webUrl.toString()
|
|
|
|
}
|
|
|
|
|
|
|
|
StatusQ.StatusLetterIdenticon {
|
|
|
|
id: identicon
|
|
|
|
anchors.horizontalCenter: parent.horizontalCenter
|
|
|
|
color: Theme.palette.baseColor2
|
|
|
|
identiconText.text: text.charAt(0)
|
|
|
|
identiconText.color: Theme.palette.baseColor1
|
|
|
|
visible: !bookmarkImage.visible && !addButton.visible
|
2020-10-27 16:53:22 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
StyledText {
|
|
|
|
id: bookmarkName
|
|
|
|
text: root.text
|
2021-08-17 19:03:03 +02:00
|
|
|
width: 67
|
2020-10-27 16:53:22 -04:00
|
|
|
anchors.top: bookmarkImage.bottom
|
|
|
|
horizontalAlignment: Text.AlignHCenter
|
2021-08-17 19:03:03 +02:00
|
|
|
font.pixelSize: Style.current.additionalTextSize
|
2020-10-27 16:53:22 -04:00
|
|
|
wrapMode: Text.WordWrap
|
|
|
|
anchors.topMargin: Style.current.halfPadding
|
2021-08-17 19:03:03 +02:00
|
|
|
maximumLineCount: 2
|
|
|
|
elide: Text.ElideRight
|
2020-10-27 16:53:22 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
MouseArea {
|
|
|
|
anchors.fill: parent
|
|
|
|
cursorShape: Qt.PointingHandCursor
|
2020-10-29 16:07:52 -04:00
|
|
|
acceptedButtons: Qt.LeftButton | Qt.RightButton
|
|
|
|
onClicked: {
|
2020-12-29 12:10:22 -05:00
|
|
|
if (mouse.button === Qt.RightButton) {
|
2020-10-29 16:07:52 -04:00
|
|
|
root.rightClicked(mouse)
|
|
|
|
} else {
|
|
|
|
root.clicked(mouse)
|
|
|
|
}
|
|
|
|
}
|
2020-10-27 16:53:22 -04:00
|
|
|
}
|
|
|
|
}
|