1 /***************************************************************************
3 * Open \______ \ ____ ____ | | _\_ |__ _______ ___
4 * Source | _// _ \_/ ___\| |/ /| __ \ / _ \ \/ /
5 * Jukebox | | ( <_> ) \___| < | \_\ ( <_> > < <
6 * Firmware |____|_ /\____/ \___ >__|_ \|___ /\____/__/\_ \
9 * (based upon 1.1 by calpefrosch) updated by www.HuwSy.ukhackers.net
13 * This program is free software; you can redistribute it and/or
14 * modify it under the terms of the GNU General Public License
15 * as published by the Free Software Foundation; either version 2
16 * of the License, or (at your option) any later version.
18 * This software is distributed on an "AS IS" basis, WITHOUT WARRANTY OF ANY
19 * KIND, either express or implied.
21 ****************************************************************************/
24 #if defined(HAVE_LCD_BITMAP) && (CONFIG_RTC != 0)
26 #include <timefuncs.h>
30 #if CONFIG_KEYPAD == RECORDER_PAD
31 #define CALENDAR_QUIT BUTTON_OFF
32 #define CALENDAR_SELECT BUTTON_PLAY
33 #define CALENDAR_NEXT_WEEK BUTTON_DOWN
34 #define CALENDAR_PREV_WEEK BUTTON_UP
35 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
36 #define CALENDAR_PREV_DAY BUTTON_LEFT
37 #define CALENDAR_NEXT_MONTH (BUTTON_ON|BUTTON_DOWN)
38 #define CALENDAR_PREV_MONTH (BUTTON_ON|BUTTON_UP)
40 #elif CONFIG_KEYPAD == ARCHOS_AV300_PAD
41 #define CALENDAR_QUIT BUTTON_OFF
42 #define CALENDAR_SELECT BUTTON_SELECT
43 #define CALENDAR_NEXT_WEEK BUTTON_DOWN
44 #define CALENDAR_PREV_WEEK BUTTON_UP
45 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
46 #define CALENDAR_PREV_DAY BUTTON_LEFT
47 #define CALENDAR_NEXT_MONTH (BUTTON_ON|BUTTON_DOWN)
48 #define CALENDAR_PREV_MONTH (BUTTON_ON|BUTTON_UP)
50 #elif CONFIG_KEYPAD == ONDIO_PAD
51 #define CALENDAR_QUIT BUTTON_OFF
52 #define CALENDAR_SELECT (BUTTON_MENU|BUTTON_REL)
53 #define CALENDAR_NEXT_WEEK BUTTON_DOWN
54 #define CALENDAR_PREV_WEEK BUTTON_UP
55 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
56 #define CALENDAR_PREV_DAY BUTTON_LEFT
57 #define CALENDAR_NEXT_MONTH (BUTTON_MENU|BUTTON_DOWN)
58 #define CALENDAR_PREV_MONTH (BUTTON_MENU|BUTTON_UP)
60 #elif (CONFIG_KEYPAD == IRIVER_H100_PAD) || \
61 (CONFIG_KEYPAD == IRIVER_H300_PAD)
62 #define CALENDAR_QUIT BUTTON_OFF
63 #define CALENDAR_SELECT BUTTON_SELECT
64 #define CALENDAR_NEXT_WEEK BUTTON_DOWN
65 #define CALENDAR_PREV_WEEK BUTTON_UP
66 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
67 #define CALENDAR_PREV_DAY BUTTON_LEFT
68 #define CALENDAR_NEXT_MONTH BUTTON_MODE
69 #define CALENDAR_PREV_MONTH BUTTON_REC
71 #elif (CONFIG_KEYPAD == IPOD_4G_PAD) || \
72 (CONFIG_KEYPAD == IPOD_3G_PAD) || \
73 (CONFIG_KEYPAD == IPOD_1G2G_PAD)
74 #define CALENDAR_QUIT (BUTTON_SELECT|BUTTON_MENU)
75 #define CALENDAR_SELECT (BUTTON_SELECT|BUTTON_PLAY)
76 #define CALENDAR_NEXT_WEEK BUTTON_SCROLL_FWD
77 #define CALENDAR_PREV_WEEK BUTTON_SCROLL_BACK
78 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
79 #define CALENDAR_PREV_DAY BUTTON_LEFT
80 #define CALENDAR_NEXT_MONTH BUTTON_PLAY
81 #define CALENDAR_PREV_MONTH BUTTON_MENU
83 #elif (CONFIG_KEYPAD == IAUDIO_X5M5_PAD)
84 #define CALENDAR_QUIT BUTTON_POWER
85 #define CALENDAR_SELECT BUTTON_SELECT
86 #define CALENDAR_NEXT_WEEK BUTTON_DOWN
87 #define CALENDAR_PREV_WEEK BUTTON_UP
88 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
89 #define CALENDAR_PREV_DAY BUTTON_LEFT
90 #define CALENDAR_NEXT_MONTH (BUTTON_PLAY|BUTTON_DOWN)
91 #define CALENDAR_PREV_MONTH (BUTTON_PLAY|BUTTON_UP)
93 #elif CONFIG_KEYPAD == GIGABEAT_PAD
94 #define CALENDAR_QUIT BUTTON_POWER
95 #define CALENDAR_SELECT BUTTON_SELECT
96 #define CALENDAR_NEXT_WEEK BUTTON_DOWN
97 #define CALENDAR_PREV_WEEK BUTTON_UP
98 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
99 #define CALENDAR_PREV_DAY BUTTON_LEFT
100 #define CALENDAR_NEXT_MONTH BUTTON_VOL_DOWN
101 #define CALENDAR_PREV_MONTH BUTTON_VOL_UP
103 #elif CONFIG_KEYPAD == SANSA_E200_PAD
104 #define CALENDAR_QUIT BUTTON_POWER
105 #define CALENDAR_SELECT BUTTON_SELECT
106 #define CALENDAR_NEXT_WEEK BUTTON_SCROLL_FWD
107 #define CALENDAR_PREV_WEEK BUTTON_SCROLL_BACK
108 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
109 #define CALENDAR_PREV_DAY BUTTON_LEFT
110 #define CALENDAR_NEXT_MONTH BUTTON_DOWN
111 #define CALENDAR_PREV_MONTH BUTTON_UP
113 #elif CONFIG_KEYPAD == SANSA_C200_PAD
114 #define CALENDAR_QUIT BUTTON_POWER
115 #define CALENDAR_SELECT BUTTON_SELECT
116 #define CALENDAR_NEXT_WEEK BUTTON_DOWN
117 #define CALENDAR_PREV_WEEK BUTTON_UP
118 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
119 #define CALENDAR_PREV_DAY BUTTON_LEFT
120 #define CALENDAR_NEXT_MONTH BUTTON_VOL_UP
121 #define CALENDAR_PREV_MONTH BUTTON_VOL_DOWN
123 #elif CONFIG_KEYPAD == IRIVER_H10_PAD
124 #define CALENDAR_QUIT BUTTON_POWER
125 #define CALENDAR_SELECT BUTTON_PLAY
126 #define CALENDAR_NEXT_WEEK BUTTON_SCROLL_DOWN
127 #define CALENDAR_PREV_WEEK BUTTON_SCROLL_UP
128 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
129 #define CALENDAR_PREV_DAY BUTTON_LEFT
130 #define CALENDAR_NEXT_MONTH BUTTON_FF
131 #define CALENDAR_PREV_MONTH BUTTON_REW
133 #elif CONFIG_KEYPAD == GIGABEAT_S_PAD
134 #define CALENDAR_QUIT BUTTON_BACK
135 #define CALENDAR_SELECT BUTTON_SELECT
136 #define CALENDAR_NEXT_WEEK BUTTON_DOWN
137 #define CALENDAR_PREV_WEEK BUTTON_UP
138 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
139 #define CALENDAR_PREV_DAY BUTTON_LEFT
140 #define CALENDAR_NEXT_MONTH BUTTON_NEXT
141 #define CALENDAR_PREV_MONTH BUTTON_PREV
143 #elif CONFIG_KEYPAD == MROBE100_PAD
144 #define CALENDAR_QUIT BUTTON_POWER
145 #define CALENDAR_SELECT BUTTON_SELECT
146 #define CALENDAR_NEXT_WEEK BUTTON_DOWN
147 #define CALENDAR_PREV_WEEK BUTTON_UP
148 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
149 #define CALENDAR_PREV_DAY BUTTON_LEFT
150 #define CALENDAR_NEXT_MONTH (BUTTON_MENU|BUTTON_DOWN)
151 #define CALENDAR_PREV_MONTH (BUTTON_MENU|BUTTON_UP)
153 #elif CONFIG_KEYPAD == IAUDIO_M3_PAD
154 #define CALENDAR_QUIT BUTTON_RC_REC
155 #define CALENDAR_SELECT BUTTON_RC_PLAY
156 #define CALENDAR_NEXT_WEEK BUTTON_RC_VOL_DOWN
157 #define CALENDAR_PREV_WEEK BUTTON_RC_VOL_UP
158 #define CALENDAR_NEXT_DAY BUTTON_RC_FF
159 #define CALENDAR_PREV_DAY BUTTON_RC_REW
160 #define CALENDAR_NEXT_MONTH BUTTON_RC_MODE
161 #define CALENDAR_PREV_MONTH BUTTON_RC_MENU
163 #elif (CONFIG_KEYPAD == COWOND2_PAD)
164 #define CALENDAR_QUIT BUTTON_POWER
165 #define CALENDAR_SELECT BUTTON_CENTER
166 #define CALENDAR_NEXT_WEEK BUTTON_DOWN
167 #define CALENDAR_PREV_WEEK BUTTON_UP
168 #define CALENDAR_NEXT_DAY BUTTON_RIGHT
169 #define CALENDAR_PREV_DAY BUTTON_LEFT
170 #define CALENDAR_NEXT_MONTH BUTTON_BOTTOMRIGHT
171 #define CALENDAR_PREV_MONTH BUTTON_BOTTOMLEFT
174 #error "No keypad setting."
177 #define X_OFFSET ((LCD_WIDTH%7)/2)
183 #define CELL_WIDTH (LCD_WIDTH / 7)
184 #define CELL_HEIGHT (LCD_HEIGHT / 7)
186 static const struct plugin_api
* rb
;
188 static bool leap_year
;
189 /* days_in_month[][0] is for December */
190 static const int days_in_month
[2][13] = {
191 {31, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31},
192 {31, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31},
195 static const char *dayname_long
[7] = {"Mon","Tue","Wed","Thu","Fri","Sat","Sun"};
196 static const char *dayname_short
[7] = {"M","T","W","T","F","S","S"};
199 int mday
; /* day of the month */
201 int year
; /* year since 1900 */
202 int wday
; /* day of the week */
206 int mday
; /* day of the month */
208 int year
; /* year since 1900 */
209 int wday
; /* day of the week */
210 int firstday
; /* first (w)day of month */
211 int lastday
; /* last (w)day of month */
214 static bool use_system_font
= false;
216 static bool been_in_usb_mode
= false;
218 /* leap year -- account for gregorian reformation in 1752 */
219 static int is_leap_year(int yr
)
221 return ((yr
) <= 1752 ? !((yr
) % 4) : \
222 (!((yr
) % 4) && ((yr
) % 100)) || !((yr
) % 400)) ? 1:0 ;
225 /* searches the weekday of the first day in month,
226 * relative to the given values */
227 static int calc_weekday( struct shown
*shown
)
229 return ( shown
->wday
+ 36 - shown
->mday
) % 7 ;
233 static void calendar_init(struct today
*today
, struct shown
*shown
)
241 rb
->lcd_getstringsize("A",&w
,&h
);
242 if ( ((w
* 14) > LCD_WIDTH
) || ((h
* 7) > LCD_HEIGHT
) )
244 rb
->lcd_setfont(FONT_SYSFIXED
);
245 use_system_font
= true;
247 rb
->lcd_clear_display();
250 today
->mon
= tm
->tm_mon
+1;
251 today
->year
= 2000+tm
->tm_year
%100;
252 today
->wday
= tm
->tm_wday
-1;
253 today
->mday
= tm
->tm_mday
;
254 shown
->mday
= today
->mday
;
255 shown
->mon
= today
->mon
;
256 shown
->year
= today
->year
;
257 shown
->wday
= today
->wday
;
259 shown
->firstday
= calc_weekday(shown
);
260 leap_year
= is_leap_year(shown
->year
);
263 static void draw_headers(void)
267 const char **dayname
= (const char**)&dayname_long
;
269 for (i
= 0; i
< 7; i
++)
271 rb
->lcd_getstringsize(dayname
[i
],&w
,&h
);
274 dayname
= (const char**)&dayname_short
;
279 rb
->lcd_getstringsize("A",&w
,&h
);
280 for (i
= 0; i
< 7; i
++)
282 rb
->lcd_putsxy(x
, 0 , dayname
[i
]);
285 rb
->lcd_hline(0, LCD_WIDTH
-1 ,h
);
288 static bool day_has_memo
[32];
289 static bool wday_has_memo
[7];
290 static void draw_calendar(struct shown
*shown
)
293 int x
,y
,pos
,days_per_month
,j
;
295 const char *monthname
[] = {
310 rb
->lcd_setfont(FONT_SYSFIXED
);
311 rb
->lcd_getstringsize("A",&w
,&h
);
312 rb
->lcd_clear_display();
314 if (shown
->firstday
> 6)
315 shown
->firstday
-= 7;
316 pos
= shown
->firstday
;
317 days_per_month
= days_in_month
[leap_year
][shown
->mon
];
318 x
= X_OFFSET
+ (pos
* CELL_WIDTH
);
320 for (j
= 1; j
<= days_per_month
; j
++)
322 if ( (day_has_memo
[j
]) || (wday_has_memo
[pos
]) )
323 rb
->snprintf(buffer
,4,"%02d.", j
);
325 rb
->snprintf(buffer
,4,"%02d", j
);
326 if (shown
->mday
== j
)
328 rb
->lcd_set_drawmode(DRMODE_SOLID
);
329 rb
->lcd_fillrect(x
, y
- 1, CELL_WIDTH
- 1, CELL_HEIGHT
);
330 rb
->lcd_set_drawmode(DRMODE_SOLID
|DRMODE_INVERSEVID
);
335 rb
->lcd_set_drawmode(DRMODE_SOLID
);
337 rb
->lcd_putsxy(x
, y
, buffer
);
347 rb
->lcd_set_drawmode(DRMODE_SOLID
);
348 rb
->lcd_vline(LCD_WIDTH
-w
*8-10,LCD_HEIGHT
-h
-3,LCD_HEIGHT
-1);
349 rb
->lcd_hline(LCD_WIDTH
-w
*8-10,LCD_WIDTH
-1,LCD_HEIGHT
-h
-3);
350 rb
->snprintf(buffer
,9,"%s %04d",monthname
[shown
->mon
-1],shown
->year
);
351 rb
->lcd_putsxy(LCD_WIDTH
-w
*8-8,LCD_HEIGHT
-h
-1,buffer
);
352 shown
->lastday
= pos
;
356 #define MAX_CHAR_MEMO_LEN 64
357 #define MAX_MEMOS_IN_A_MONTH 128
359 char message
[MAX_CHAR_MEMO_LEN
];
362 int file_pointer_start
;
363 int file_pointer_end
;
367 } memos
[MAX_MEMOS_IN_A_MONTH
];
368 static int pointer_array
[MAX_MEMOS_IN_A_MONTH
];
369 static int memos_in_memory
= 0;
370 static int memos_in_shown_memory
= 0;
372 static void load_memo(struct shown
*shown
)
382 for (k
= 0; k
< memos_in_memory
; k
++)
386 memos
[k
].file_pointer_start
= 0;
387 memos
[k
].file_pointer_end
= 0;
391 for (i
= 0; i
< MAX_CHAR_MEMO_LEN
; i
++)
392 memos
[k
].message
[i
] = 0;
394 for (k
= 1; k
< 32; k
++)
395 day_has_memo
[k
] = false;
396 for (k
= 0; k
< 7; k
++)
397 wday_has_memo
[k
] = false;
399 fp
= rb
->open(ROCKBOX_DIR
"/.memo",O_RDONLY
);
402 int count
= rb
->filesize(fp
);
403 rb
->lseek(fp
, 0, SEEK_SET
);
406 memos
[memos_in_memory
].file_pointer_start
= rb
->lseek(fp
, 0,
408 if (rb
->read(fp
, temp_memo2
, 2) == 2)
409 memos
[memos_in_memory
].day
= rb
->atoi(&temp_memo2
[0]);
411 memos
[memos_in_memory
].day
= 0;
412 if (rb
->read(fp
, temp_memo2
, 2) == 2)
413 memos
[memos_in_memory
].month
= rb
->atoi(&temp_memo2
[0]);
415 memos
[memos_in_memory
].month
= 0;
416 if (rb
->read(fp
, temp_memo4
, 4) == 4)
417 memos
[memos_in_memory
].year
= rb
->atoi(&temp_memo4
[0]);
419 memos
[memos_in_memory
].year
= 0;
420 /* as the year returned is sometimes yearmonth, ie if yr should =
421 2003, and month = 06, then it returns 200306 */
422 if (memos
[memos_in_memory
].year
> (shown
->year
* 10))
423 memos
[memos_in_memory
].year
= (memos
[memos_in_memory
].year
-
424 memos
[memos_in_memory
].month
) /
426 if (rb
->read(fp
, temp_memo1
, 1) == 1)
427 memos
[memos_in_memory
].wday
= rb
->atoi(&temp_memo1
[0]);
429 memos
[memos_in_memory
].wday
= 0;
430 if (rb
->read(fp
, temp_memo1
, 1) == 1)
431 memos
[memos_in_memory
].type
= rb
->atoi(&temp_memo1
[0]);
433 memos
[memos_in_memory
].type
= 0;
434 for (k
= 0; k
<= count
; k
++)
436 if (rb
->read(fp
, temp_memo1
, 1) == 1)
439 (memos
[memos_in_memory
].type
< 2)
442 (memos
[memos_in_memory
].type
== 2)
444 (memos
[memos_in_memory
].month
== shown
->mon
)
448 (memos
[memos_in_memory
].type
> 2)
450 (memos
[memos_in_memory
].month
== shown
->mon
)
452 (memos
[memos_in_memory
].year
== shown
->year
)
456 if (temp_memo1
[0] == '\n')
458 if (memos
[memos_in_memory
].type
> 0)
459 day_has_memo
[memos
[memos_in_memory
].day
] =
462 wday_has_memo
[memos
[memos_in_memory
].wday
] =
464 memos
[memos_in_memory
++].file_pointer_end
=
465 rb
->lseek(fp
, 0, SEEK_CUR
);
467 else if ( (temp_memo1
[0] != '\r') &&
468 (temp_memo1
[0] != '\t') &&
469 k
< MAX_CHAR_MEMO_LEN
-1 )
470 memos
[memos_in_memory
].message
[k
] = temp_memo1
[0];
472 if (temp_memo1
[0] == '\n')
477 memos
[memos_in_memory
].day
= 0;
478 memos
[memos_in_memory
].month
= 0;
479 memos
[memos_in_memory
].file_pointer_start
= 0;
480 memos
[memos_in_memory
].file_pointer_end
= 0;
481 memos
[memos_in_memory
].year
= 0;
482 memos
[memos_in_memory
].type
= 0;
483 memos
[memos_in_memory
].wday
= 0;
484 memos
[memos_in_memory
].message
[0] = 0;
494 static bool save_memo(int changed
, bool new_mod
, struct shown
*shown
)
497 fp
= rb
->open(ROCKBOX_DIR
"/.memo",O_RDONLY
| O_CREAT
);
498 fq
= rb
->creat(ROCKBOX_DIR
"/~temp");
499 if ( (fq
!= -1) && (fp
!= -1) )
502 char temp
[MAX_CHAR_MEMO_LEN
];
503 rb
->lseek(fp
, 0, SEEK_SET
);
504 for (i
= 0; i
< memos
[changed
].file_pointer_start
; i
++)
506 rb
->read(fp
, temp
, 1);
507 rb
->write(fq
,temp
,1);
511 rb
->fdprintf(fq
, "%02d%02d%04d%01d%01d%s\n",
513 memos
[changed
].month
,
517 memos
[changed
].message
);
519 rb
->lseek(fp
, memos
[changed
].file_pointer_end
, SEEK_SET
);
520 while(rb
->read(fp
, temp
, 1) == 1)
522 rb
->write(fq
,temp
,1);
526 rb
->remove(ROCKBOX_DIR
"/.memo");
527 rb
->rename(ROCKBOX_DIR
"/~temp", ROCKBOX_DIR
"/.memo");
538 static void add_memo(struct shown
*shown
, int type
)
541 if (rb
->kbd_input(memos
[memos_in_memory
].message
,
542 sizeof memos
[memos_in_memory
].message
) != -1)
544 if (rb
->strlen(memos
[memos_in_memory
].message
))
546 memos
[memos_in_memory
].file_pointer_start
= 0;
547 memos
[memos_in_memory
].file_pointer_end
= 0;
548 memos
[memos_in_memory
].day
= shown
->mday
;
549 memos
[memos_in_memory
].month
= shown
->mon
;
550 memos
[memos_in_memory
].wday
= shown
->wday
;
551 memos
[memos_in_memory
].year
= shown
->year
;
552 memos
[memos_in_memory
].type
= type
;
553 if (save_memo(memos_in_memory
,true,shown
))
559 memos
[memos_in_memory
].file_pointer_start
= 0;
560 memos
[memos_in_memory
].file_pointer_end
= 0;
561 memos
[memos_in_memory
].day
= 0;
562 memos
[memos_in_memory
].month
= 0;
563 memos
[memos_in_memory
].year
= 0;
564 memos
[memos_in_memory
].type
= 0;
565 memos
[memos_in_memory
].wday
= 0;
569 rb
->lcd_clear_display();
571 rb
->lcd_setfont(FONT_SYSFIXED
);
573 rb
->splash(HZ
/2,"Event added");
575 rb
->splash(HZ
/2,"Event not added");
578 static int edit_menu_cb(int action
, const struct menu_item_ex
*this_item
)
581 if (action
== ACTION_REQUEST_MENUITEM
&& memos_in_shown_memory
<= 0)
582 return ACTION_EXIT_MENUITEM
;
586 static bool edit_memo(int change
, struct shown
*shown
)
591 MENUITEM_RETURNVALUE(edit_menu_remove
, "Remove", 0,
592 edit_menu_cb
, Icon_NOICON
);
593 MENUITEM_RETURNVALUE(edit_menu_edit
, "Edit", 1,
594 edit_menu_cb
, Icon_NOICON
);
595 MENUITEM_RETURNVALUE(edit_menu_weekly
, "New Weekly", 2,
597 MENUITEM_RETURNVALUE(edit_menu_monthly
, "New Monthly", 3,
599 MENUITEM_RETURNVALUE(edit_menu_yearly
, "New Yearly", 4,
601 MENUITEM_RETURNVALUE(edit_menu_oneoff
, "New One off", 5,
604 MAKE_MENU(edit_menu
, "Edit menu",
606 &edit_menu_remove
, &edit_menu_edit
,
607 &edit_menu_weekly
, &edit_menu_monthly
,
608 &edit_menu_yearly
, &edit_menu_oneoff
);
612 switch (rb
->do_menu(&edit_menu
, &selected
, NULL
, false))
615 save_memo(pointer_array
[change
],false,shown
);
619 if(rb
->kbd_input(memos
[pointer_array
[change
]].message
,
620 sizeof memos
[pointer_array
[change
]].message
) != -1)
621 save_memo(pointer_array
[change
],true,shown
);
628 case 3: /* monthly */
636 case 5: /* one off */
643 case MENU_ATTACHED_USB
:
644 been_in_usb_mode
= true;
651 static char * get_event_text(int selected
, void *data
,
652 char *buffer
, size_t buffer_len
)
654 struct shown
*shown
= (struct shown
*) data
;
655 if (selected
< 0 || memos_in_shown_memory
<= selected
)
659 if (memos
[pointer_array
[selected
]].type
== 2)
660 rb
->snprintf(buffer
, buffer_len
, "%s (%d yrs)",
661 memos
[pointer_array
[selected
]].message
,
662 shown
->year
- memos
[pointer_array
[selected
]].year
);
664 rb
->snprintf(buffer
, buffer_len
, "%s",
665 memos
[pointer_array
[selected
]].message
);
669 static bool view_events(int selected
, struct shown
*shown
)
671 struct gui_synclist gui_memos
;
675 rb
->gui_synclist_init(&gui_memos
, &get_event_text
, shown
, false, 1, NULL
);
676 rb
->gui_synclist_set_title(&gui_memos
, "Events (play : menu)", NOICON
);
677 rb
->gui_synclist_set_nb_items(&gui_memos
, memos_in_shown_memory
);
678 rb
->gui_synclist_select_item(&gui_memos
, selected
);
679 rb
->gui_synclist_draw(&gui_memos
);
683 rb
->gui_syncstatusbar_draw(rb
->statusbars
, true);
684 button
= rb
->get_action(CONTEXT_LIST
,TIMEOUT_BLOCK
);
685 rb
->gui_synclist_do_button(&gui_memos
,&button
,LIST_WRAP_UNLESS_HELD
);
690 selected
= rb
->gui_synclist_get_sel_pos(&gui_memos
);
691 return edit_memo(selected
, shown
);
694 case ACTION_STD_CANCEL
:
699 if(rb
->default_event_handler(button
) == SYS_USB_CONNECTED
)
700 been_in_usb_mode
= true;
708 static void update_memos_shown(struct shown
*shown
)
711 memos_in_shown_memory
= 0;
712 for (i
= 0; i
< memos_in_memory
; i
++)
717 (memos
[i
].day
== shown
->mday
)
723 (memos
[i
].wday
== shown
->wday
)
726 pointer_array
[memos_in_shown_memory
++] = i
;
729 static bool any_events(struct shown
*shown
, bool force
)
731 update_memos_shown(shown
);
733 if (memos_in_shown_memory
> 0)
734 return view_events(0, shown
);
736 return edit_memo(0, shown
);
743 static void next_month(struct shown
*shown
, int step
)
750 leap_year
= is_leap_year(shown
->year
);
753 shown
->mday
= shown
->mday
- days_in_month
[leap_year
][shown
->mon
-1];
754 else if (shown
->mday
> days_in_month
[leap_year
][shown
->mon
])
755 shown
->mday
= days_in_month
[leap_year
][shown
->mon
];
756 shown
->firstday
= shown
->lastday
;
758 draw_calendar(shown
);
761 static void prev_month(struct shown
*shown
, int step
)
768 leap_year
= is_leap_year(shown
->year
);
771 shown
->mday
= shown
->mday
+ days_in_month
[leap_year
][shown
->mon
];
772 else if (shown
->mday
> days_in_month
[leap_year
][shown
->mon
])
773 shown
->mday
= days_in_month
[leap_year
][shown
->mon
];
774 shown
->firstday
+= 7 - (days_in_month
[leap_year
][shown
->mon
] % 7);
776 draw_calendar(shown
);
779 static void next_day(struct shown
*shown
, int step
)
782 if (shown
->mday
> days_in_month
[leap_year
][shown
->mon
])
783 next_month(shown
, step
);
785 draw_calendar(shown
);
788 static void prev_day(struct shown
*shown
, int step
)
792 prev_month(shown
, step
);
794 draw_calendar(shown
);
797 enum plugin_status
plugin_start(const struct plugin_api
* api
, const void* parameter
)
808 calendar_init(&today
, &shown
);
810 any_events(&shown
, false);
811 draw_calendar(&shown
);
814 button
= rb
->button_get(true);
820 case CALENDAR_NEXT_MONTH
:
821 case CALENDAR_NEXT_MONTH
| BUTTON_REPEAT
:
822 next_month(&shown
, 0);
825 case CALENDAR_PREV_MONTH
:
826 case CALENDAR_PREV_MONTH
| BUTTON_REPEAT
:
827 prev_month(&shown
, 0);
830 case CALENDAR_NEXT_WEEK
:
831 case CALENDAR_NEXT_WEEK
| BUTTON_REPEAT
:
835 case CALENDAR_PREV_WEEK
:
836 case CALENDAR_PREV_WEEK
| BUTTON_REPEAT
:
840 case CALENDAR_PREV_DAY
:
841 case CALENDAR_PREV_DAY
| BUTTON_REPEAT
:
845 case CALENDAR_NEXT_DAY
:
846 case CALENDAR_NEXT_DAY
| BUTTON_REPEAT
:
850 case CALENDAR_SELECT
:
851 any_events(&shown
, true);
852 draw_calendar(&shown
);
856 if(rb
->default_event_handler(button
) == SYS_USB_CONNECTED
)
857 been_in_usb_mode
= true;
858 draw_calendar(&shown
);
862 return been_in_usb_mode
?PLUGIN_USB_CONNECTED
:PLUGIN_OK
;