mirror of https://github.com/cutefishos/calculator
You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
70 lines
2.5 KiB
QML
70 lines
2.5 KiB
QML
import QtQuick 2.12
|
|
import QtQuick.Layouts 1.3
|
|
import QtQuick.Controls 2.5
|
|
import MeuiKit 1.0 as Meui
|
|
|
|
Item {
|
|
id: buttonsView
|
|
|
|
property var labels
|
|
property var targets
|
|
property int rowsCount: 5
|
|
|
|
signal buttonClicked(string strToAppend)
|
|
signal buttonLongPressed(string strToAppend)
|
|
|
|
Grid {
|
|
id: grid
|
|
anchors.centerIn: parent
|
|
anchors.margins: Meui.Units.smallSpacing
|
|
columns: getColumnsCount()
|
|
rows: buttonsView.rowsCount
|
|
|
|
Repeater {
|
|
model: buttonsView.labels
|
|
|
|
MouseArea {
|
|
id: buttonRect
|
|
width: buttonsView.width / grid.columns - Meui.Units.smallSpacing / 2
|
|
height: buttonsView.height / grid.rows - Meui.Units.smallSpacing / 2
|
|
onClicked: buttonsView.buttonClicked(targets[index])
|
|
onPressAndHold: buttonsView.buttonLongPressed(targets[index])
|
|
|
|
Rectangle {
|
|
anchors.centerIn: parent
|
|
radius: Meui.Theme.smallRadius
|
|
width: parent.width - radius
|
|
height: parent.height - radius
|
|
color: buttonRect.pressed ? Meui.Theme.highlightColor : Qt.rgba(Meui.Theme.backgroundColor.r,
|
|
Meui.Theme.backgroundColor.g,
|
|
Meui.Theme.backgroundColor.b, 0.5)
|
|
|
|
border.width: 1
|
|
border.color: Meui.Theme.darkMode ? Qt.lighter(Meui.Theme.backgroundColor, 1.1) : Qt.darker(Meui.Theme.backgroundColor, 1.1)
|
|
|
|
Behavior on color {
|
|
ColorAnimation {
|
|
duration: 50
|
|
}
|
|
}
|
|
}
|
|
|
|
Text {
|
|
anchors.fill: parent
|
|
text: modelData
|
|
horizontalAlignment: Qt.AlignHCenter
|
|
verticalAlignment: Qt.AlignVCenter
|
|
fontSizeMode: Text.Fit
|
|
minimumPointSize: Math.round(buttonRect.height / 5)
|
|
font.pointSize: Math.round(buttonRect.height / 5)
|
|
color: buttonRect.pressed ? Meui.Theme.highlightedTextColor : Meui.Theme.textColor
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
function getColumnsCount() {
|
|
return Math.ceil(buttonsView.labels.length / buttonsView.rowsCount);
|
|
}
|
|
}
|