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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
|
import QtQuick 2.0
import Ubuntu.Components 0.1
MainView {
id: mainView
objectName: "calendar"
applicationName: "calendar"
width: units.gu(45)
height: units.gu(80)
// FIXME: 80/45 = aspect ration of Galaxy Nexus
Tabs { // preliminary HACK, needs rewrite when NewTabBar is finalized!
id: tabs
anchors.fill: parent
Tab { id: pageArea; title: i18n.tr("January"); page: Item { anchors.fill: parent } }
Tab { title: i18n.tr("February") }
Tab { title: i18n.tr("March") }
Tab { title: i18n.tr("April") }
Tab { title: i18n.tr("May") }
Tab { title: i18n.tr("June") }
Tab { title: i18n.tr("July") }
Tab { title: i18n.tr("August") }
Tab { title: i18n.tr("September") }
Tab { title: i18n.tr("October") }
Tab { title: i18n.tr("November") }
Tab { title: i18n.tr("December") }
onSelectedTabIndexChanged: monthView.gotoNextMonth(selectedTabIndex)
}
Rectangle {
anchors.fill: monthView
color: "white"
}
MonthView {
id: monthView
onMonthStartChanged: tabs.selectedTabIndex = monthStart.getMonth()
y: pageArea.y
onMovementEnded: eventView.currentDayStart = currentDayStart
onCurrentDayStartChanged: if (!(dragging || flicking)) eventView.currentDayStart = currentDayStart
Component.onCompleted: eventView.currentDayStart = currentDayStart
}
EventView {
id: eventView
property real minY: pageArea.y + monthView.compressedHeight
property real maxY: pageArea.y + monthView.expandedHeight
y: maxY
width: mainView.width
height: parent.height - y
expanded: monthView.compressed
Component.onCompleted: {
incrementCurrentDay.connect(monthView.incrementCurrentDay)
decrementCurrentDay.connect(monthView.decrementCurrentDay)
}
onExpand: {
monthView.compressed = true
yBehavior.enabled = true
y = minY
}
onCompress: {
monthView.compressed = false
y = maxY
}
Behavior on y {
id: yBehavior
enabled: false
NumberAnimation { duration: 100 }
}
}
tools: ToolbarActions {
Action {
iconSource: Qt.resolvedUrl("avatar.png")
text: i18n.tr("To-do")
onTriggered:; // FIXME
}
Action {
iconSource: Qt.resolvedUrl("avatar.png")
text: i18n.tr("New Event")
onTriggered:; // FIXME
}
Action {
iconSource: Qt.resolvedUrl("avatar.png")
text: i18n.tr("Timeline")
onTriggered:; // FIXME
}
}
}
|