[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:
parent
13dc03991d
commit
4ebf130ee6
@ -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
|
||||||
|
@ -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
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -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: {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user