[Calendar] Add proper back/forward buttons and a "Today" button

This removes the custom label-based triangles and replaces them with proper ToolButtons
using proper icons. It also adds a "Today" button to return to the current day.
The tooltips on the buttons reflect the actual action ("Previous Month", "Previous Year",
"Previous Decade", depending on the zoom level).

Furthermore, the day names and week numbers now use the regular font size but they're still
visually disconnected. The day names row is hidden in the zoom levels now.

REVIEW: 126960
BUG: 336124
BUG: 348362
BUG: 358536
This commit is contained in:
Kai Uwe Broulik 2016-02-08 00:07:43 +01:00
parent 13dc03991d
commit 4ebf130ee6
3 changed files with 82 additions and 80 deletions

View File

@ -103,13 +103,17 @@ MouseArea {
Components.Label { Components.Label {
id: label id: label
anchors.fill: todayRect anchors {
fill: todayRect
margins: units.smallSpacing
}
horizontalAlignment: Text.AlignHCenter horizontalAlignment: Text.AlignHCenter
verticalAlignment: Text.AlignVCenter verticalAlignment: Text.AlignVCenter
text: model.label || dayNumber text: model.label || dayNumber
opacity: isCurrent ? 1.0 : 0.5 opacity: isCurrent ? 1.0 : 0.5
wrapMode: Text.NoWrap wrapMode: Text.NoWrap
elide: Text.ElideRight elide: Text.ElideRight
fontSizeMode: Text.HorizontalFit
font.pixelSize: Math.max(theme.smallestFont.pixelSize, Math.floor(daysCalendar.cellHeight / 3)) font.pixelSize: Math.max(theme.smallestFont.pixelSize, Math.floor(daysCalendar.cellHeight / 3))
// This is to avoid the "Both point size and // This is to avoid the "Both point size and
// pixel size set. Using pixel size" warnings // pixel size set. Using pixel size" warnings

View File

@ -1,7 +1,7 @@
/* /*
* Copyright 2013 Heena Mahour <heena393@gmail.com> * Copyright 2013 Heena Mahour <heena393@gmail.com>
* Copyright 2013 Sebastian Kügler <sebas@kde.org> * Copyright 2013 Sebastian Kügler <sebas@kde.org>
* Copyright 2015 Kai Uwe Broulik <kde@privat.broulik.de> * Copyright 2015, 2016 Kai Uwe Broulik <kde@privat.broulik.de>
* *
* This program is free software; you can redistribute it and/or * This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as * modify it under the terms of the GNU General Public License as
@ -16,7 +16,9 @@
* You should have received a copy of the GNU General Public License * You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>. * along with this program. If not, see <http://www.gnu.org/licenses/>.
*/ */
import QtQuick 2.2 import QtQuick 2.2
import QtQuick.Layouts 1.1
import QtQuick.Controls 1.1 import QtQuick.Controls 1.1
import org.kde.plasma.calendar 2.0 import org.kde.plasma.calendar 2.0
@ -38,6 +40,9 @@ Item {
readonly property int gridColumns: showWeekNumbers ? calendarGrid.columns + 1 : calendarGrid.columns readonly property int gridColumns: showWeekNumbers ? calendarGrid.columns + 1 : calendarGrid.columns
property alias previousLabel: previousButton.tooltip
property alias nextLabel: nextButton.tooltip
property int rows property int rows
property int columns property int columns
@ -56,7 +61,7 @@ Item {
// Take the calendar width, subtract the inner and outer spacings and divide by number of columns (==days in week) // Take the calendar width, subtract the inner and outer spacings and divide by number of columns (==days in week)
readonly property int cellWidth: Math.floor((stack.width - (daysCalendar.columns + 1) * root.borderWidth) / (daysCalendar.columns + (showWeekNumbers ? 1 : 0))) readonly property int cellWidth: Math.floor((stack.width - (daysCalendar.columns + 1) * root.borderWidth) / (daysCalendar.columns + (showWeekNumbers ? 1 : 0)))
// Take the calendar height, subtract the inner spacings and divide by number of rows (root.weeks + one row for day names) // Take the calendar height, subtract the inner spacings and divide by number of rows (root.weeks + one row for day names)
readonly property int cellHeight: Math.floor((stack.height - heading.height - (daysCalendar.rows + 1) * root.borderWidth) / (daysCalendar.rows + 1)) readonly property int cellHeight: Math.floor((stack.height - heading.height - calendarGrid.rows * root.borderWidth) / calendarGrid.rows)
property real transformScale: 1 property real transformScale: 1
property point transformOrigin: Qt.point(width / 2, height / 2) property point transformOrigin: Qt.point(width / 2, height / 2)
@ -82,90 +87,79 @@ Item {
} }
} }
PlasmaExtras.Heading { RowLayout {
id: heading
anchors { anchors {
top: parent.top top: parent.top
left: parent.left left: parent.left
right: parent.right right: parent.right
} }
spacing: units.smallSpacing
level: 1 PlasmaExtras.Heading {
elide: Text.ElideRight id: heading
font.capitalization: Font.Capitalize
MouseArea { Layout.fillWidth: true
id: monthMouse
property int previousPixelDelta
anchors.fill: parent level: 1
onClicked: { elide: Text.ElideRight
if (!stack.busy) { font.capitalization: Font.Capitalize
daysCalendar.headerClicked()
}
}
onExited: previousPixelDelta = 0
onWheel: {
var delta = wheel.angleDelta.y || wheel.angleDelta.x
var pixelDelta = wheel.pixelDelta.y || wheel.pixelDelta.x
// For high-precision touchpad scrolling, we get a wheel event for basically every slightest MouseArea {
// finger movement. To prevent the view from suddenly ending up in the next century, we id: monthMouse
// cumulate all the pixel deltas until they're larger than the label and then only change property int previousPixelDelta
// the month. Standard mouse wheel scrolling is unaffected since it's fine.
if (pixelDelta) { anchors.fill: parent
if (Math.abs(previousPixelDelta) < monthMouse.height) { onClicked: {
previousPixelDelta += pixelDelta if (!stack.busy) {
return daysCalendar.headerClicked()
} }
} }
onExited: previousPixelDelta = 0
onWheel: {
var delta = wheel.angleDelta.y || wheel.angleDelta.x
var pixelDelta = wheel.pixelDelta.y || wheel.pixelDelta.x
if (delta >= 15) { // For high-precision touchpad scrolling, we get a wheel event for basically every slightest
daysCalendar.previous() // finger movement. To prevent the view from suddenly ending up in the next century, we
} else if (delta <= -15) { // cumulate all the pixel deltas until they're larger than the label and then only change
daysCalendar.next() // the month. Standard mouse wheel scrolling is unaffected since it's fine.
if (pixelDelta) {
if (Math.abs(previousPixelDelta) < monthMouse.height) {
previousPixelDelta += pixelDelta
return
}
}
if (delta >= 15) {
daysCalendar.previous()
} else if (delta <= -15) {
daysCalendar.next()
}
previousPixelDelta = 0
} }
previousPixelDelta = 0
} }
} }
}
Components.Label { Components.ToolButton {
anchors { id: previousButton
top: heading.bottom iconName: "go-previous"
left: parent.left
leftMargin: Math.floor(units.largeSpacing / 2)
}
text: "◀"
opacity: leftmouse.containsMouse ? 1 : 0.4
Behavior on opacity { NumberAnimation {} }
MouseArea {
id: leftmouse
anchors.fill: parent
anchors.margins: -units.largeSpacing / 3
hoverEnabled: true
onClicked: daysCalendar.previous() onClicked: daysCalendar.previous()
Accessible.name: tooltip
} }
}
Components.Label { Components.ToolButton {
anchors { iconName: "go-jump-today"
top: heading.bottom onClicked: root.resetToToday()
right: parent.right tooltip: i18ndc("libplasma5", "Reset calendar to today", "Today")
rightMargin: Math.floor(units.largeSpacing / 2) Accessible.name: tooltip
Accessible.description: i18nd("libplasma5", "Reset calendar to today")
} }
text: "▶"
opacity: rightmouse.containsMouse ? 1 : 0.4
Behavior on opacity { NumberAnimation {} }
MouseArea { Components.ToolButton {
id: rightmouse id: nextButton
anchors.fill: parent iconName: "go-next"
anchors.margins: -units.largeSpacing / 3
hoverEnabled: true
onClicked: daysCalendar.next() onClicked: daysCalendar.next()
Accessible.name: tooltip
} }
} }
@ -221,7 +215,7 @@ Item {
// Draw the outer vertical lines in full height so that it closes // Draw the outer vertical lines in full height so that it closes
// the outer rectangle // the outer rectangle
if (i == 0 || i == gridColumns) { if (i == 0 || i == gridColumns || !daysCalendar.headerModel) {
ctx.moveTo(lineX, 0); ctx.moveTo(lineX, 0);
} else { } else {
ctx.moveTo(lineX, root.borderWidth + daysCalendar.cellHeight); ctx.moveTo(lineX, root.borderWidth + daysCalendar.cellHeight);
@ -266,7 +260,7 @@ Item {
verticalAlignment: Text.AlignVCenter verticalAlignment: Text.AlignVCenter
opacity: 0.4 opacity: 0.4
text: modelData text: modelData
font.pixelSize: Math.max(theme.smallestFont.pixelSize, daysCalendar.cellHeight / 6) font.pixelSize: Math.max(theme.smallestFont.pixelSize, daysCalendar.cellHeight / 3)
} }
} }
} }
@ -282,7 +276,7 @@ Item {
} }
columns: daysCalendar.columns columns: daysCalendar.columns
rows: daysCalendar.rows + 1 rows: daysCalendar.rows + (daysCalendar.headerModel ? 1 : 0)
spacing: root.borderWidth spacing: root.borderWidth
property Item selectedItem property Item selectedItem
@ -300,19 +294,14 @@ Item {
Repeater { Repeater {
id: days id: days
Item { Components.Label {
width: daysCalendar.cellWidth width: daysCalendar.cellWidth
height: daysCalendar.cellHeight height: daysCalendar.cellHeight
text: Qt.locale().dayName(calendarBackend.firstDayOfWeek + index, Locale.ShortFormat)
Components.Label { font.pixelSize: Math.max(theme.smallestFont.pixelSize, daysCalendar.cellHeight / 3)
text: Qt.locale().dayName(calendarBackend.firstDayOfWeek + index, Locale.ShortFormat) opacity: 0.4
font.pixelSize: Math.max(theme.smallestFont.pixelSize, daysCalendar.cellHeight / 6) horizontalAlignment: Text.AlignHCenter
horizontalAlignment: Text.AlignHCenter verticalAlignment: Text.AlignVCenter
verticalAlignment: Text.AlignBottom
anchors.horizontalCenter: parent.horizontalCenter
anchors.bottom: parent.bottom
anchors.bottomMargin: units.smallSpacing
}
} }
} }

View File

@ -232,13 +232,16 @@ PinchArea {
dateMatchingPrecision: Calendar.MatchYearMonthAndDay dateMatchingPrecision: Calendar.MatchYearMonthAndDay
previousLabel: i18nd("libplasma5", "Previous Month")
nextLabel: i18nd("libplasma5", "Next Month")
onPrevious: calendarBackend.previousMonth() onPrevious: calendarBackend.previousMonth()
onNext: calendarBackend.nextMonth() onNext: calendarBackend.nextMonth()
onHeaderClicked: { onHeaderClicked: {
stack.push(yearOverview) stack.push(yearOverview)
} }
onActivated: { onActivated: {
var rowNumber = Math.floor(index / 7); var rowNumber = Math.floor(index / columns);
week = 1 + calendarBackend.weeksModel[rowNumber]; week = 1 + calendarBackend.weeksModel[rowNumber];
root.date = date root.date = date
root.currentDate = new Date(date.yearNumber, date.monthNumber - 1, date.dayNumber) root.currentDate = new Date(date.yearNumber, date.monthNumber - 1, date.dayNumber)
@ -258,6 +261,9 @@ PinchArea {
gridModel: monthModel gridModel: monthModel
previousLabel: i18nd("libplasma5", "Previous Year")
nextLabel: i18nd("libplasma5", "Next Year")
onPrevious: calendarBackend.previousYear() onPrevious: calendarBackend.previousYear()
onNext: calendarBackend.nextYear() onNext: calendarBackend.nextYear()
onHeaderClicked: { onHeaderClicked: {
@ -288,6 +294,9 @@ PinchArea {
gridModel: yearModel gridModel: yearModel
previousLabel: i18nd("libplasma5", "Previous Decade")
nextLabel: i18nd("libplasma5", "Next Decade")
onPrevious: calendarBackend.previousDecade() onPrevious: calendarBackend.previousDecade()
onNext: calendarBackend.nextDecade() onNext: calendarBackend.nextDecade()
onActivated: { onActivated: {