feat(StatusTagItem): Created new control that represents a tag item
Created new `StatusTagItem` control and added that represents a tag item with a `text`, `icon` and `isReadonly` properties.
This commit is contained in:
parent
70834fc187
commit
d69b0598bf
116
src/StatusQ/Controls/StatusTagItem.qml
Normal file
116
src/StatusQ/Controls/StatusTagItem.qml
Normal file
@ -0,0 +1,116 @@
|
|||||||
|
import QtQuick 2.14
|
||||||
|
|
||||||
|
import StatusQ.Core 0.1
|
||||||
|
import StatusQ.Core.Theme 0.1
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\qmltype StatusTagItem
|
||||||
|
\inherits Item
|
||||||
|
\inqmlmodule StatusQ.Controls
|
||||||
|
\since StatusQ.Controls 0.1
|
||||||
|
\brief Reprsents a tag item.
|
||||||
|
Inherits \l{https://doc.qt.io/qt-5/qml-qtquick-rectangle.html}{Item}.
|
||||||
|
|
||||||
|
The \c StatusTagItem represents a tag item where a name and icon can be displayed and can be clicked.
|
||||||
|
Example:
|
||||||
|
|
||||||
|
\qml
|
||||||
|
StatusTagItem {
|
||||||
|
isReadonly: model.isReadonly
|
||||||
|
text: model.name
|
||||||
|
icon: model.tagIcon
|
||||||
|
|
||||||
|
onClicked: { console.log("Tag selected!") }
|
||||||
|
}
|
||||||
|
\endqml
|
||||||
|
|
||||||
|
For a list of components available see StatusQ.
|
||||||
|
*/
|
||||||
|
Rectangle {
|
||||||
|
id: root
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\qmlproperty bool StatusTagItem::isReadonly
|
||||||
|
This property sets if the tag is readonly or not.
|
||||||
|
*/
|
||||||
|
property bool isReadonly
|
||||||
|
/*!
|
||||||
|
\qmlproperty string StatusTagItem::name
|
||||||
|
This property sets the tag text to display.
|
||||||
|
*/
|
||||||
|
property string text
|
||||||
|
/*!
|
||||||
|
\qmlproperty string StatusTagItem::icon
|
||||||
|
This property sets the tag icon to display.
|
||||||
|
*/
|
||||||
|
property string icon
|
||||||
|
|
||||||
|
/*!
|
||||||
|
\qmlsignal
|
||||||
|
This signal is emitted when the tag is clicked.
|
||||||
|
*/
|
||||||
|
signal clicked()
|
||||||
|
|
||||||
|
QtObject {
|
||||||
|
id: d
|
||||||
|
property int tagMargins: 8
|
||||||
|
property int tagIconsSize: 20
|
||||||
|
|
||||||
|
function getTagColor(isReadonly) {
|
||||||
|
if(isReadonly) {
|
||||||
|
return Theme.palette.baseColor1
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
return mouseArea.containsMouse ? Theme.palette.miscColor1 : Theme.palette.primaryColor1
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
width: tagRow.implicitWidth + 2 * d.tagMargins
|
||||||
|
height: 30
|
||||||
|
color: d.getTagColor(root.isReadonly)
|
||||||
|
radius: 8
|
||||||
|
Row {
|
||||||
|
id: tagRow
|
||||||
|
height: parent.height
|
||||||
|
anchors.left: parent.left
|
||||||
|
anchors.leftMargin: d.tagMargins
|
||||||
|
anchors.rightMargin: d.tagMargins
|
||||||
|
spacing: 2
|
||||||
|
|
||||||
|
StatusIcon {
|
||||||
|
visible: root.icon
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
color: Theme.palette.indirectColor1
|
||||||
|
width: root.icon ? d.tagIconsSize : 0
|
||||||
|
height: d.tagIconsSize
|
||||||
|
icon: root.icon
|
||||||
|
}
|
||||||
|
StatusBaseText {
|
||||||
|
id: nameText
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
color: Theme.palette.indirectColor1
|
||||||
|
font.pixelSize: 15
|
||||||
|
text: root.text
|
||||||
|
}
|
||||||
|
StatusIcon {
|
||||||
|
id: closeIcon
|
||||||
|
visible: !root.isReadonly
|
||||||
|
anchors.leftMargin: d.tagMargins
|
||||||
|
anchors.verticalCenter: parent.verticalCenter
|
||||||
|
color: Theme.palette.indirectColor1
|
||||||
|
width: d.tagIconsSize
|
||||||
|
height: d.tagIconsSize
|
||||||
|
icon: "close"
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
MouseArea {
|
||||||
|
id: mouseArea
|
||||||
|
enabled: !root.isReadonly
|
||||||
|
anchors.fill: parent
|
||||||
|
hoverEnabled: true
|
||||||
|
cursorShape: enabled ? Qt.PointingHandCursor : Qt.ArrowCursor
|
||||||
|
onClicked: { root.clicked() }
|
||||||
|
}
|
||||||
|
}
|
@ -35,6 +35,7 @@ StatusSwitchTabBar 0.1 StatusSwitchTabBar.qml
|
|||||||
StatusSelectableText 0.1 StatusSelectableText.qml
|
StatusSelectableText 0.1 StatusSelectableText.qml
|
||||||
StatusTabBar 0.1 StatusTabBar.qml
|
StatusTabBar 0.1 StatusTabBar.qml
|
||||||
StatusTabButton 0.1 StatusTabButton.qml
|
StatusTabButton 0.1 StatusTabButton.qml
|
||||||
|
StatusTagItem 0.1 StatusTagItem.qml
|
||||||
StatusTokenInlineSelector 0.1 StatusTokenInlineSelector.qml
|
StatusTokenInlineSelector 0.1 StatusTokenInlineSelector.qml
|
||||||
StatusWalletColorButton 0.1 StatusWalletColorButton.qml
|
StatusWalletColorButton 0.1 StatusWalletColorButton.qml
|
||||||
StatusWalletColorSelect 0.1 StatusWalletColorSelect.qml
|
StatusWalletColorSelect 0.1 StatusWalletColorSelect.qml
|
||||||
|
@ -10501,5 +10501,6 @@
|
|||||||
<file>src/assets/twemoji/svg/e50a.svg</file>
|
<file>src/assets/twemoji/svg/e50a.svg</file>
|
||||||
<file>src/assets/twemoji/LICENSE</file>
|
<file>src/assets/twemoji/LICENSE</file>
|
||||||
<file>src/StatusQ/Controls/StatusTabBar.qml</file>
|
<file>src/StatusQ/Controls/StatusTabBar.qml</file>
|
||||||
|
<file>src/StatusQ/Controls/StatusTagItem.qml</file>
|
||||||
</qresource>
|
</qresource>
|
||||||
</RCC>
|
</RCC>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user