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
|
/*
* Copyright (C) 2014 Canonical Ltd
*
* This file is part of Ubuntu Calendar App
*
* Ubuntu Calendar App is free software: you can redistribute it and/or modify
* it under the terms of the GNU General Public License version 3 as
* published by the Free Software Foundation.
*
* Ubuntu Calendar App is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
import QtQuick 2.3
import Ubuntu.Components 1.1
import Ubuntu.SyncMonitor 0.1
Item {
id: actionPool
property alias newEventAction: _newEventAction
property alias showCalendarAction: _showCalendarAction
property alias syncCalendarAction: _syncCalendarAction
Action {
id: _syncCalendarAction
objectName: "syncbutton"
iconName: "reload"
// TRANSLATORS: Please translate this string to 15 characters only.
// Currently ,there is no way we can increase width of action menu currently.
text: enabled ? i18n.tr("Sync") : i18n.tr("Syncing")
onTriggered: syncMonitor.sync(["calendar"])
enabled: (syncMonitor.state !== "syncing")
visible: syncMonitor.enabledServices ? syncMonitor.serviceIsEnabled("calendar") : false
}
SyncMonitor {
id: syncMonitor
}
Action {
id: _newEventAction
objectName: "neweventbutton"
iconName: "new-event"
text: i18n.tr("New Event")
onTriggered: {
pageStack.push(Qt.resolvedUrl("NewEvent.qml"),{"date":tabs.currentDay,"model":eventModel});
}
}
Action{
id: _showCalendarAction
objectName: "calendarsbutton"
iconName: "calendar"
text: i18n.tr("Calendars")
onTriggered: {
pageStack.push(Qt.resolvedUrl("CalendarChoicePopup.qml"),{"model":eventModel});
pageStack.currentPage.collectionUpdated.connect(eventModel.delayedApplyFilter);
}
}
}
|