1
0
Fork 0
forked from len0rd/rockbox

plugins: clock: simplify settings

- Use system time format and remove separate setting
- Hide timer until started & eliminate setting for it
- Simplify menu, reorder settings, keep theme enabled
- Make dialog for resetting settings more consistent
  with other reset dialogs

Change-Id: I0fd38612b0592cd5a650c8985f377acc70a48eb7
This commit is contained in:
Christian Soffke 2025-06-07 20:58:09 +02:00
parent ab161a3d89
commit 8d4efb6cf2
6 changed files with 60 additions and 95 deletions

View file

@ -33,7 +33,7 @@ static const struct opt_items noyes_text[] = {
static const struct opt_items backlight_settings_text[] = {
{ "Always Off", -1 },
{ "Use Rockbox Setting", -1 },
{ "Use System Setting", -1 },
{ "Always On", -1 }
};
@ -49,17 +49,12 @@ static const struct opt_items date_format_text[] = {
{ "Japanese (Y-M-D)", -1 },
};
static const struct opt_items hour_format_text[] = {
{ "24-Hour", -1 },
{ "12-Hour", -1 }
};
/***************
* Select a mode, returs true when the mode has been selected
* (we go back to clock display then)
**************/
static bool menu_mode_selector(void){
MENUITEM_STRINGLIST(menu,"Mode Selector",NULL, "Analog",
MENUITEM_STRINGLIST(menu,"Mode",NULL, "Analog",
"Digital", "Binary");
if(rb->do_menu(&menu, &clock_settings.mode, NULL, false) >=0)
return(true);
@ -73,7 +68,7 @@ static void menu_analog_settings(void)
{
int selection=0, result=0;
MENUITEM_STRINGLIST(menu,"Analog Mode Settings",NULL,"Show Date",
MENUITEM_STRINGLIST(menu,"Analog",NULL,"Show Date",
"Show Second Hand","Show Border");
while(result>=0){
@ -103,7 +98,7 @@ static void menu_analog_settings(void)
static void menu_digital_settings(void){
int selection=0, result=0;
MENUITEM_STRINGLIST(menu,"Digital Mode Settings",NULL,"Show Seconds",
MENUITEM_STRINGLIST(menu,"Digital",NULL,"Show Seconds",
"Blinking Colon");
while(result>=0){
@ -123,62 +118,45 @@ static void menu_digital_settings(void){
}
}
/***********************************************************
* Confirm resetting of settings, used in general_settings()
**********************************************************/
static void confirm_reset(void){
int result=0;
rb->set_option("Reset all settings?", &result, RB_INT, noyes_text, 2, NULL);
if(result == 1){ /* reset! */
clock_settings_reset(&clock_settings);
rb->splash(HZ, "Settings reset!");
}
else
rb->splash(HZ, "Settings NOT reset.");
}
/************************************
* General settings. Reset, save, etc
***********************************/
static void menu_general_settings(void){
static int menu_general_settings(void){
int selection=0, result=0;
MENUITEM_STRINGLIST(menu,"General Settings",NULL,
"Hour Format","Date Format","Show Counter",
"Reset Settings","Save Settings Now",
"Save On Exit","Backlight Settings",
"Idle Poweroff (temporary)");
MENUITEM_STRINGLIST(menu, "Clock Settings", NULL,
"Analog", "Digital",
"Date Format", "Backlight", "Idle Poweroff",
"Save on Exit", "Save", "Reset");
while(result>=0){
result=rb->do_menu(&menu, &selection, NULL, false);
switch(result){
case 0:
rb->set_option("Hour format",
&clock_settings.general.hour_format,
RB_INT, hour_format_text, 2, NULL);
menu_analog_settings();
break;
case 1:
rb->set_option("Date format",
menu_digital_settings();
break;
case 2:
rb->set_option("Date Format",
&clock_settings.general.date_format,
RB_INT, date_format_text, 4, NULL);
break;
case 2:
rb->set_option("Show Counter", &clock_settings.general.show_counter,
RB_BOOL, noyes_text, 2, NULL);
break;
case 3:
confirm_reset();
rb->set_option("Backlight",
&clock_settings.general.backlight,
RB_INT, backlight_settings_text, 3, NULL);
apply_backlight_setting(clock_settings.general.backlight);
break;
case 4:
save_settings_wo_gui();
rb->splash(HZ, "Settings saved");
rb->set_option("Idle Poweroff",
&clock_settings.general.idle_poweroff,
RB_BOOL, idle_poweroff_text, 2, NULL);
break;
case 5:
rb->set_option("Save On Exit",
rb->set_option("Save on Exit",
&clock_settings.general.save_settings,
RB_BOOL, noyes_text, 2, NULL);
@ -188,64 +166,51 @@ static void menu_general_settings(void){
save_settings_wo_gui();
break;
case 6:
rb->set_option("Backlight Settings",
&clock_settings.general.backlight,
RB_INT, backlight_settings_text, 3, NULL);
apply_backlight_setting(clock_settings.general.backlight);
save_settings_wo_gui();
rb->splash(HZ, ID2P(LANG_SETTINGS_SAVED));
break;
case 7:
rb->set_option("Idle Poweroff (temporary)",
&clock_settings.general.idle_poweroff,
RB_BOOL, idle_poweroff_text, 2, NULL);
if (rb->yesno_pop_confirm(ID2P(LANG_RESET)))
{
clock_settings_reset(&clock_settings);
return 1;
}
break;
}
}
return 0;
}
/***********
* Main menu
**********/
bool main_menu(void){
int selection=0;
bool main_menu(void)
{
int selection = 0;
bool done = false;
bool exit_clock=false;
MENUITEM_STRINGLIST(menu,"Clock Menu",NULL,"View Clock","Mode Selector",
"Mode Settings","General Settings","Playback Control",
MENUITEM_STRINGLIST(menu, "Clock", NULL, "Mode",
"Settings","Playback Control",
"Quit");
while(!done){
switch(rb->do_menu(&menu, &selection, NULL, false)){
while (!done)
{
switch(rb->do_menu(&menu, &selection, NULL, false))
{
case 0:
done = true;
break;
case 1:
done=menu_mode_selector();
break;
case 1:
if (menu_general_settings())
done = true;
break;
case 2:
switch(clock_settings.mode){
case ANALOG: menu_analog_settings();break;
case DIGITAL: menu_digital_settings();break;
case BINARY: /* no settings */;break;
}
break;
case 3:
menu_general_settings();
break;
case 4:
playback_control(NULL);
break;
case 5:
case 3:
exit_clock = true;
done = true;
break;
default:
done=true;
break;