1 // XCCalendarManipulator.cpp - Xestia Calendar XCCalendarManipulator widget class.
3 // (c) 2016 Xestia Software Development.
5 // This file is part of Xestia Calendar.
7 // Xestia Address Book is free software: you can redistribute it and/or modify
8 // it under the terms of the GNU General Public License as published by the
9 // Free Software Foundation, version 3 of the license.
11 // Xestia Address Book is distributed in the hope that it will be useful,
12 // but WITHOUT ANY WARRANTY; without even the implied warranty of
13 // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 // GNU General Public License for more details.
16 // You should have received a copy of the GNU General Public License along
17 // with Xestia Calendar. If not, see <http://www.gnu.org/licenses/>
19 #include "XCCalendarManipulator.h"
21 wxDEFINE_EVENT(XCCALENDARMANIPULATOR_CHANGEGRID, wxCommandEvent);
25 XCCalendarManipulator::XCCalendarManipulator(wxWindow* parent, const wxString& title,
26 const wxPoint& pos, const wxSize& size, CalendarDataStorage *dataStorage)
27 : wxPanel(parent, wxID_ANY, pos, size, wxTAB_TRAVERSAL, title){
28 szrMain = new wxBoxSizer( wxVERTICAL );
29 pnlMain = new wxPanel(this, wxID_ANY, wxDefaultPosition, wxSize(500, 50), wxTAB_TRAVERSAL);
30 pnlMain->SetBackgroundColour(wxColour(40,40,40));
31 this->SetSizer(szrMain);
32 szrMain->Add(pnlMain, 0, wxEXPAND, 0);
34 // Setup the navigation section.
36 szrNavigation = new wxBoxSizer( wxHORIZONTAL );
37 pnlMain->SetSizer(szrNavigation);
39 // Add next month and previous month buttons.
41 previousButton = new wxButton(pnlMain, wxID_ANY, wxT(""), wxDefaultPosition, wxSize(32,32), 0|wxNO_BORDER);
42 nextButton = new wxButton(pnlMain, wxID_ANY, wxT(""), wxDefaultPosition, wxSize(32,32), 0|wxNO_BORDER);
43 calendarsButton = new wxButton(pnlMain, wxID_ANY, wxT(""), wxDefaultPosition, wxSize(32,32), 0|wxNO_BORDER);
45 wxMemoryInputStream previousIcon(icons_previous_png, sizeof(icons_previous_png));
46 wxMemoryInputStream nextIcon(icons_next_png, sizeof(icons_next_png));
47 wxMemoryInputStream calendarsIcon(icons_calendars_png, sizeof(icons_calendars_png));
49 wxImage icons_previous_png(previousIcon, wxBITMAP_TYPE_PNG);
50 previousIconBitmap = wxBitmap(icons_previous_png, -1);
52 wxImage icons_next_png(nextIcon, wxBITMAP_TYPE_PNG);
53 nextIconBitmap = wxBitmap(icons_next_png, -1);
55 wxImage icons_calendars_png(calendarsIcon, wxBITMAP_TYPE_PNG);
56 calendarsIconBitmap = wxBitmap(icons_calendars_png, -1);
58 previousButton->SetBitmap(previousIconBitmap);
59 nextButton->SetBitmap(nextIconBitmap);
60 calendarsButton->SetBitmap(calendarsIconBitmap);
61 previousButton->SetBackgroundColour(pnlMain->GetBackgroundColour());
62 nextButton->SetBackgroundColour(pnlMain->GetBackgroundColour());
63 calendarsButton->SetBackgroundColour(pnlMain->GetBackgroundColour());
65 // Setup the static text.
67 dateButton = new wxButton(pnlMain, wxID_ANY, wxT(""), wxDefaultPosition, wxDefaultSize, 0|wxNO_BORDER);
71 test.SetWeight(wxFONTWEIGHT_BOLD);
72 test.SetPointSize(18);
74 dateButton->SetFont(test);
75 dateButton->SetForegroundColour(wxColour(255,255,255));
76 dateButton->SetBackgroundColour(pnlMain->GetBackgroundColour());
78 // Setup the manipulator control.
80 szrNavigation->Add(previousButton, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5);
81 szrNavigation->Add(calendarsButton, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5);
82 szrNavigation->Add( 0, 0, 1, wxEXPAND, 5 );
83 szrNavigation->Add(dateButton, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5 );
84 szrNavigation->Add( 0, 0, 1, wxEXPAND, 5 );
85 szrNavigation->Add(nextButton, 0, wxALL|wxALIGN_CENTER_VERTICAL, 5);
86 szrNavigation->Layout();
88 // Setup the month selection control.
90 wxDateTime dtNow = wxDateTime::Now();
92 moo = new XCCalendarMonthSelect(this);
93 month = ((int)dtNow.GetMonth() + 1);
94 year = dtNow.GetYear();
95 moo->UpdateDate(month, year);
96 UpdateDateButtonText();
98 // Setup the calendars list.
100 calendarList = new XCCalendarList(this);
102 // Setup the calendar data storage pointer.
104 this->dataStorage = dataStorage;
106 // Setup the event controls.
108 dateButton->Connect(wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler(XCCalendarManipulator::DateTextClick), NULL, this);
109 nextButton->Connect(wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler(XCCalendarManipulator::NextMonth), NULL, this);
110 calendarsButton->Connect(wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler(XCCalendarManipulator::ShowCalendarsList), NULL, this);
111 previousButton->Connect(wxEVT_COMMAND_BUTTON_CLICKED, wxCommandEventHandler(XCCalendarManipulator::PreviousMonth), NULL, this);
113 Bind(XCCALENDARMANIPULATOR_CHANGEGRID, &XCCalendarManipulator::ChangeGrid, this, ID_CHANGEGRID);
116 XCCalendarManipulator::~XCCalendarManipulator(){
118 // Destory the controls from the widget.
122 void XCCalendarManipulator::DateTextClick(wxCommandEvent &event){
124 // Bring up a popup control to select the month and year.
126 moo->SetPosition(wxPoint(dateButton->GetScreenRect().GetLeft(), dateButton->GetScreenRect().GetBottom()));
127 moo->UpdateDate(month, year);
132 void XCCalendarManipulator::ChangeGrid(wxCommandEvent &event){
134 if (month == moo->GetMonth() && year == moo->GetYear()){
138 month = moo->GetMonth();
139 year = moo->GetYear();
141 // Post an event to the parent control to update the grid.
143 wxCommandEvent changeGrid(XCCALENDARCTRL_CHANGEGRID);
144 changeGrid.SetId(ID_CHANGEGRID);
145 wxPostEvent(this->GetParent(), changeGrid);
147 UpdateDateButtonText();
151 void XCCalendarManipulator::NextMonth(wxCommandEvent &event){
156 // Get the current month and year.
158 newMonth = moo->GetMonth();
159 newYear = moo->GetYear();
171 moo->UpdateDate(month, year);
173 // Post an event to the parent control to update the grid.
175 wxCommandEvent changeGrid(XCCALENDARCTRL_CHANGEGRID);
176 changeGrid.SetId(ID_CHANGEGRID);
177 wxPostEvent(this->GetParent(), changeGrid);
179 UpdateDateButtonText();
183 void XCCalendarManipulator::PreviousMonth(wxCommandEvent &event){
188 // Get the current month and year.
190 newMonth = moo->GetMonth();
191 newYear = moo->GetYear();
203 moo->UpdateDate(month, year);
205 // Post an event to the parent control to update the grid.
207 wxCommandEvent changeGrid(XCCALENDARCTRL_CHANGEGRID);
208 changeGrid.SetId(ID_CHANGEGRID);
209 wxPostEvent(this->GetParent(), changeGrid);
211 UpdateDateButtonText();
215 void XCCalendarManipulator::ShowCalendarsList(wxCommandEvent &event){
217 // Update the list of calendars before showing.
219 calendarList->SetPosition(wxPoint(calendarsButton->GetScreenRect().GetLeft(), calendarsButton->GetScreenRect().GetBottom()));
220 calendarList->UpdateCalendarList(dataStorage);
221 calendarList->Popup();
225 void XCCalendarManipulator::UpdateDateButtonText(){
227 // Update the date text.
229 string newDateText = "";
231 switch (moo->GetMonth()){
233 newDateText = _("January");
236 newDateText = _("February");
239 newDateText = _("March");
242 newDateText = _("April");
245 newDateText = _("May");
248 newDateText = _("June");
251 newDateText = _("July");
254 newDateText = _("August");
257 newDateText = _("September");
260 newDateText = _("October");
263 newDateText = _("November");
266 newDateText = _("December");
272 newDateText += to_string(year);
274 dateButton->SetLabel(newDateText);
279 int XCCalendarManipulator::GetMonth(){
285 int XCCalendarManipulator::GetYear(){
291 vector<int> XCCalendarManipulator::GetHiddenAccountsList(){
293 return calendarList->GetHiddenAccountsList();
297 vector<int> XCCalendarManipulator::GetHiddenCalendarsList(){
299 return calendarList->GetHiddenCalendarsList();