2 * Copyright (C) 2012-2013 Andy Spencer <andy753421@gmail.com>
4 * This program is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation, either version 3 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <http://www.gnu.org/licenses/>.
32 /* Helper functions */
33 static void print_month(month_t month, int y, int x)
35 event_t *event = EVENTS;
36 const char *name = month_to_string(month);
37 const int start = start_of_month(SEL.year, month);
38 const char days = days_in_month(SEL.year, month);
39 mvwprintw(win, y, x+MW/2-strlen(name)/2, "%s", name);
41 for (int d = 0; d < 7; d++)
42 wprintw(win, "%-3s", day_to_st(d));
43 for (int d = 0; d < days; d++) {
44 int row = (start + d) / 7;
45 int col = (start + d) % 7;
48 while (event && before(&event->start, SEL.year, month, d, 24, 0)) {
49 if (!before(&event->start, SEL.year, month, d, 0, 0))
54 int today = month == SEL.month && d == SEL.day;
56 int attr = (busy ? A_BOLD|A_UNDERLINE : A_DIM)
57 | (today ? A_REVERSE : 0 );
60 mvwprintw(win, y+2+row, x+col*3, "%2d", d+1);
66 void year_init(WINDOW *_win)
72 void year_size(int rows, int cols)
85 cal_load(SEL.year, 0, 0, 366);
87 /* Determine heights */
88 for (int m = 0; m < 12; m++) {
89 int weeks = weeks_in_month(SEL.year, m);
90 h[m/3] = MAX(h[m/3], weeks+2);
92 int sum = h[0]+h[1]+h[2]+h[3];
95 if (COMPACT) wattron(win, A_REVERSE | A_BOLD);
96 if (COMPACT) mvwhline(win, y, 0, A_REVERSE | A_BOLD, COLS);
97 mvwprintw(win, y++, COLS/2-2, "%d", SEL.year);
98 if (COMPACT) wattroff(win, A_REVERSE | A_BOLD);
101 for (int m = 0; m < 12; m++) {
102 print_month(m, y, x);
113 mvwvline(win, y, x+(MW+3)*1-2, ACS_VLINE, sum+3);
114 mvwvline(win, y, x+(MW+3)*2-2, ACS_VLINE, sum+3);
115 for (int i = 0; i < 3; i++) {
117 mvwhline(win, y, x, ACS_HLINE, w);
118 mvwaddch(win, y, x+(MW+3)*1-2, ACS_PLUS);
119 mvwaddch(win, y, x+(MW+3)*2-2, ACS_PLUS);
125 int year_run(int key, mmask_t btn, int row, int col)
128 month_t m = SEL.month;
130 wday_t day = day_of_week(SEL.year, SEL.month, SEL.day);
131 int week = (start_of_month(y, m) + d) / 7;
141 if (key == 'h' || key == 'k')
143 if (key == 'j' || key == 'l')
147 if (key == 'j' || key == 'k') {
148 for (int i = 0; i < 90/7; i++) {
149 add_days(&y, &m, &d, dir*7);
150 if (day_of_week(y, m, d) == day &&
151 y == SEL.year && m%3 == SEL.month%3) {
159 /* Step left/right */
160 if (key == 'h' || key == 'l') {
161 for (int i = 0; i < 90; i++) {
162 add_days(&y, &m, &d, dir);
163 if ((start_of_month(y, m) + d) / 7 == week &&
164 y == SEL.year && m/3 == SEL.month/3) {
173 if (dir || y != SEL.year) {
178 return dir || y != SEL.year;