mirror of
https://github.com/monero-project/monero-gui.git
synced 2025-01-18 16:54:39 +00:00
DatePicker: minimum and maximum dates; "First transaction" and "Today" links
This commit is contained in:
parent
7c379e2cda
commit
6b37abc577
2 changed files with 84 additions and 5 deletions
|
@ -33,6 +33,7 @@ import QtQuick.Layouts 1.2
|
||||||
import QtGraphicalEffects 1.0
|
import QtGraphicalEffects 1.0
|
||||||
import QtQuick.Controls.Styles 1.2
|
import QtQuick.Controls.Styles 1.2
|
||||||
import FontAwesome 1.0
|
import FontAwesome 1.0
|
||||||
|
import moneroComponents.TransactionHistoryModel 1.0
|
||||||
|
|
||||||
import "." as MoneroComponents
|
import "." as MoneroComponents
|
||||||
import "effects/" as MoneroEffects
|
import "effects/" as MoneroEffects
|
||||||
|
@ -45,6 +46,11 @@ Item {
|
||||||
property color backgroundColor : MoneroComponents.Style.appWindowBorderColor
|
property color backgroundColor : MoneroComponents.Style.appWindowBorderColor
|
||||||
property color errorColor : "red"
|
property color errorColor : "red"
|
||||||
property bool error: false
|
property bool error: false
|
||||||
|
property bool isFromDatePicker: false
|
||||||
|
property bool isCalendarDisplayingMinimumDate: calendar.visibleMonth == calendar.minimumDate.getMonth() && calendar.visibleYear == calendar.minimumDate.getFullYear()
|
||||||
|
property bool isCalendarDisplayingMaximumDate: calendar.visibleMonth == calendar.maximumDate.getMonth() && calendar.visibleYear == calendar.maximumDate.getFullYear()
|
||||||
|
property alias minimumDate: calendar.minimumDate
|
||||||
|
property alias maximumDate: calendar.maximumDate
|
||||||
property alias inputLabel: inputLabel
|
property alias inputLabel: inputLabel
|
||||||
|
|
||||||
signal dateChanged();
|
signal dateChanged();
|
||||||
|
@ -264,7 +270,7 @@ Item {
|
||||||
color: MoneroComponents.Style.middlePanelBackgroundColor
|
color: MoneroComponents.Style.middlePanelBackgroundColor
|
||||||
border.width: 1
|
border.width: 1
|
||||||
border.color: MoneroComponents.Style.appWindowBorderColor
|
border.color: MoneroComponents.Style.appWindowBorderColor
|
||||||
height: datePicker.expanded ? calendar.height + 2 : 0
|
height: datePicker.expanded ? calendar.height + todayLabel.height + 2 : 0
|
||||||
clip: true
|
clip: true
|
||||||
|
|
||||||
Behavior on height {
|
Behavior on height {
|
||||||
|
@ -275,8 +281,8 @@ Item {
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
scrollGestureEnabled: false
|
scrollGestureEnabled: false
|
||||||
onWheel: {
|
onWheel: {
|
||||||
if (wheel.angleDelta.y > 0) return calendar.showPreviousMonth();
|
if (wheel.angleDelta.y > 0 && !isCalendarDisplayingMinimumDate) return calendar.showPreviousMonth();
|
||||||
if (wheel.angleDelta.y < 0) return calendar.showNextMonth();
|
if (wheel.angleDelta.y < 0 && !isCalendarDisplayingMaximumDate) return calendar.showNextMonth();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -299,6 +305,7 @@ Item {
|
||||||
anchors.bottomMargin: 10
|
anchors.bottomMargin: 10
|
||||||
height: 220
|
height: 220
|
||||||
frameVisible: false
|
frameVisible: false
|
||||||
|
selectedDate: currentDate
|
||||||
|
|
||||||
style: CalendarStyle {
|
style: CalendarStyle {
|
||||||
gridVisible: false
|
gridVisible: false
|
||||||
|
@ -416,6 +423,7 @@ Item {
|
||||||
id: prevMonthIcon
|
id: prevMonthIcon
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
image: "qrc:///images/prevMonth.png"
|
image: "qrc:///images/prevMonth.png"
|
||||||
|
visible: !isCalendarDisplayingMinimumDate
|
||||||
height: 8
|
height: 8
|
||||||
width: 12
|
width: 12
|
||||||
fontAwesomeFallbackIcon: FontAwesome.arrowLeft
|
fontAwesomeFallbackIcon: FontAwesome.arrowLeft
|
||||||
|
@ -424,6 +432,7 @@ Item {
|
||||||
}
|
}
|
||||||
|
|
||||||
MouseArea {
|
MouseArea {
|
||||||
|
visible: !isCalendarDisplayingMinimumDate
|
||||||
hoverEnabled: true
|
hoverEnabled: true
|
||||||
cursorShape: Qt.PointingHandCursor
|
cursorShape: Qt.PointingHandCursor
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
|
@ -442,6 +451,7 @@ Item {
|
||||||
id: nextMonthIcon
|
id: nextMonthIcon
|
||||||
anchors.centerIn: parent
|
anchors.centerIn: parent
|
||||||
image: "qrc:///images/prevMonth.png"
|
image: "qrc:///images/prevMonth.png"
|
||||||
|
visible: !isCalendarDisplayingMaximumDate
|
||||||
height: 8
|
height: 8
|
||||||
width: 12
|
width: 12
|
||||||
rotation: 180
|
rotation: 180
|
||||||
|
@ -451,6 +461,7 @@ Item {
|
||||||
}
|
}
|
||||||
|
|
||||||
MouseArea {
|
MouseArea {
|
||||||
|
visible: !isCalendarDisplayingMaximumDate
|
||||||
hoverEnabled: true
|
hoverEnabled: true
|
||||||
cursorShape: Qt.PointingHandCursor
|
cursorShape: Qt.PointingHandCursor
|
||||||
anchors.fill: parent
|
anchors.fill: parent
|
||||||
|
@ -460,6 +471,57 @@ Item {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
MoneroComponents.TextPlain {
|
||||||
|
anchors.top: calendar.bottom
|
||||||
|
anchors.topMargin: -4
|
||||||
|
anchors.left: calendar.left
|
||||||
|
anchors.leftMargin: 5
|
||||||
|
font.family: MoneroComponents.Style.fontMonoRegular.name
|
||||||
|
font.pixelSize: 13
|
||||||
|
color: firstTransactionMouseArea.containsMouse ? MoneroComponents.Style.buttonBackgroundColorHover : MoneroComponents.Style.buttonBackgroundColor
|
||||||
|
themeTransition: false
|
||||||
|
visible: isFromDatePicker && typeof root.model !== 'undefined' && root.model != null && root.model.rowCount() > 0
|
||||||
|
text: qsTr("First transaction") + translationManager.emptyString
|
||||||
|
|
||||||
|
MouseArea {
|
||||||
|
id: firstTransactionMouseArea
|
||||||
|
hoverEnabled: true
|
||||||
|
cursorShape: Qt.PointingHandCursor
|
||||||
|
anchors.fill: parent
|
||||||
|
onClicked: {
|
||||||
|
if (appWindow.currentWallet != null && typeof root.model !== 'undefined' && root.model != null) {
|
||||||
|
datePicker.currentDate = root.model.data(root.model.index((root.model.rowCount() - 1), 0), TransactionHistoryModel.TransactionDateRole);
|
||||||
|
}
|
||||||
|
popup.close()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
MoneroComponents.TextPlain {
|
||||||
|
id: todayLabel
|
||||||
|
anchors.top: calendar.bottom
|
||||||
|
anchors.topMargin: -4
|
||||||
|
anchors.right: calendar.right
|
||||||
|
anchors.rightMargin: 5
|
||||||
|
font.family: MoneroComponents.Style.fontMonoRegular.name
|
||||||
|
font.pixelSize: 13
|
||||||
|
color: todayLabelMouseArea.containsMouse ? MoneroComponents.Style.buttonBackgroundColorHover : MoneroComponents.Style.buttonBackgroundColor
|
||||||
|
themeTransition: false
|
||||||
|
visible: !isFromDatePicker
|
||||||
|
text: qsTr("Today") + translationManager.emptyString
|
||||||
|
|
||||||
|
MouseArea {
|
||||||
|
id: todayLabelMouseArea
|
||||||
|
hoverEnabled: true
|
||||||
|
cursorShape: Qt.PointingHandCursor
|
||||||
|
anchors.fill: parent
|
||||||
|
onClicked: {
|
||||||
|
datePicker.currentDate = new Date();
|
||||||
|
popup.close()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -203,6 +203,21 @@ Rectangle {
|
||||||
width: 100
|
width: 100
|
||||||
inputLabel.text: qsTr("Date from") + translationManager.emptyString
|
inputLabel.text: qsTr("Date from") + translationManager.emptyString
|
||||||
inputLabel.font.pixelSize: 14
|
inputLabel.font.pixelSize: 14
|
||||||
|
minimumDate: {
|
||||||
|
if (appWindow.currentWallet != null && typeof root.model !== 'undefined' && root.model != null) {
|
||||||
|
var count = root.model.rowCount()
|
||||||
|
if (count > 0) {
|
||||||
|
//date of the first transaction
|
||||||
|
return root.model.data(root.model.index((count - 1), 0), TransactionHistoryModel.TransactionDateRole);
|
||||||
|
} else {
|
||||||
|
//date of monero birth
|
||||||
|
return new Date("2014-04-18");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
maximumDate: toDatePicker.currentDate
|
||||||
|
isFromDatePicker: true
|
||||||
|
|
||||||
onCurrentDateChanged: {
|
onCurrentDateChanged: {
|
||||||
if(root.initialized){
|
if(root.initialized){
|
||||||
root.reset();
|
root.reset();
|
||||||
|
@ -216,6 +231,8 @@ Rectangle {
|
||||||
Layout.fillWidth: true
|
Layout.fillWidth: true
|
||||||
width: 100
|
width: 100
|
||||||
inputLabel.text: qsTr("Date to") + translationManager.emptyString
|
inputLabel.text: qsTr("Date to") + translationManager.emptyString
|
||||||
|
minimumDate: fromDatePicker.currentDate
|
||||||
|
maximumDate: new Date() //today
|
||||||
|
|
||||||
onCurrentDateChanged: {
|
onCurrentDateChanged: {
|
||||||
if(root.initialized){
|
if(root.initialized){
|
||||||
|
@ -1784,8 +1801,8 @@ Rectangle {
|
||||||
//date of the first transaction
|
//date of the first transaction
|
||||||
fromDatePicker.currentDate = root.model.data(root.model.index((count - 1), 0), TransactionHistoryModel.TransactionDateRole);
|
fromDatePicker.currentDate = root.model.data(root.model.index((count - 1), 0), TransactionHistoryModel.TransactionDateRole);
|
||||||
} else {
|
} else {
|
||||||
//date of monero birth (2014-04-18)
|
//date of monero birth
|
||||||
fromDatePicker.currentDate = model.transactionHistory.firstDateTime
|
fromDatePicker.currentDate = new Date("2014-04-18");
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue