1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59
|
// Copyright (C) 2017 The Qt Company Ltd.
// SPDX-License-Identifier: LicenseRef-Qt-Commercial OR BSD-3-Clause
import QtQuick
Item {
id: root
implicitHeight: frame.height
implicitWidth: row.implicitWidth
width: implicitWidth
height: implicitHeight
property alias text: label.text
property bool checked
property alias pressed: tapHandler.pressed
property alias row: row
signal clicked
SystemPalette { id: palette }
Row {
id: row
anchors.verticalCenter: parent.verticalCenter
spacing: 6
Rectangle {
id: frame
gradient: Gradient {
GradientStop { position: 0.0; color: tapHandler.pressed ? Qt.darker(palette.button, 1.3) : palette.button }
GradientStop { position: 1.0; color: Qt.darker(palette.button, 1.3) }
}
height: label.implicitHeight * 1.5
width: height
anchors.margins: 1
radius: 3
antialiasing: true
border.color: Qt.darker(palette.button, 1.5)
Image {
id: theX
source: "images/checkmark.png"
anchors.fill: frame
anchors.margins: frame.width / 5
fillMode: Image.PreserveAspectFit
smooth: true
visible: root.checked
}
}
Text {
id: label
color: palette.text
anchors.verticalCenter: frame.verticalCenter
}
}
TapHandler {
id: tapHandler
onTapped: {
parent.checked = !parent.checked
parent.clicked()
}
}
}
|