summaryrefslogtreecommitdiff
path: root/Userland/Applications
diff options
context:
space:
mode:
authorSam Atkins <atkinssj@serenityos.org>2022-04-21 11:55:21 +0100
committerBrian Gianforcaro <b.gianfo@gmail.com>2022-04-23 10:48:51 -0700
commitc80fca78b3d53173a69ddb6d6233e014677c1474 (patch)
tree4042889f4ec5006686e5209e465a8fd305c7e285 /Userland/Applications
parentab377914319fd3bc11eca03bfa38a6ca46dd5fd6 (diff)
downloadserenity-c80fca78b3d53173a69ddb6d6233e014677c1474.zip
ClockSettings: Select radio-button that matches the saved clock format
This means that if you save and close ClockSettings with "24-hour" and "Show seconds" both checked, then they will both be checked when you re-open ClockSettings, instead of it showing as a "Custom" format.
Diffstat (limited to 'Userland/Applications')
-rw-r--r--Userland/Applications/ClockSettings/ClockSettingsWidget.cpp34
1 files changed, 29 insertions, 5 deletions
diff --git a/Userland/Applications/ClockSettings/ClockSettingsWidget.cpp b/Userland/Applications/ClockSettings/ClockSettingsWidget.cpp
index f344c6d910..047520302a 100644
--- a/Userland/Applications/ClockSettings/ClockSettingsWidget.cpp
+++ b/Userland/Applications/ClockSettings/ClockSettingsWidget.cpp
@@ -1,5 +1,6 @@
/*
* Copyright (c) 2022, cflip <cflip@cflip.net>
+ * Copyright (c) 2022, Sam Atkins <atkinssj@serenityos.org>
*
* SPDX-License-Identifier: BSD-2-Clause
*/
@@ -11,6 +12,11 @@
#include <LibGUI/RadioButton.h>
#include <LibGUI/TextBox.h>
+constexpr StringView time_format_12h = "%I:%M %p";
+constexpr StringView time_format_12h_seconds = "%r";
+constexpr StringView time_format_24h = "%R";
+constexpr StringView time_format_24h_seconds = "%T";
+
ClockSettingsWidget::ClockSettingsWidget()
{
load_from_gml(clock_settings_widget_gml);
@@ -19,10 +25,28 @@ ClockSettingsWidget::ClockSettingsWidget()
auto& twelve_hour_radio = *find_descendant_of_type_named<GUI::RadioButton>("12hour_radio");
m_show_seconds_checkbox = *find_descendant_of_type_named<GUI::CheckBox>("seconds_checkbox");
auto& custom_radio = *find_descendant_of_type_named<GUI::RadioButton>("custom_radio");
- custom_radio.set_checked(true);
+ auto saved_format = Config::read_string("Taskbar", "Clock", "TimeFormat");
m_custom_format_input = *find_descendant_of_type_named<GUI::TextBox>("custom_format_input");
- m_custom_format_input->set_text(Config::read_string("Taskbar", "Clock", "TimeFormat"));
+ m_custom_format_input->set_text(saved_format);
+ m_custom_format_input->set_enabled(false);
+
+ if (saved_format == time_format_12h) {
+ twelve_hour_radio.set_checked(true, GUI::AllowCallback::No);
+ m_show_seconds_checkbox->set_checked(false, GUI::AllowCallback::No);
+ } else if (saved_format == time_format_12h_seconds) {
+ twelve_hour_radio.set_checked(true, GUI::AllowCallback::No);
+ m_show_seconds_checkbox->set_checked(true, GUI::AllowCallback::No);
+ } else if (saved_format == time_format_24h) {
+ m_24_hour_radio->set_checked(true, GUI::AllowCallback::No);
+ m_show_seconds_checkbox->set_checked(false, GUI::AllowCallback::No);
+ } else if (saved_format == time_format_24h_seconds) {
+ m_24_hour_radio->set_checked(true, GUI::AllowCallback::No);
+ m_show_seconds_checkbox->set_checked(true, GUI::AllowCallback::No);
+ } else {
+ custom_radio.set_checked(true);
+ m_custom_format_input->set_enabled(true);
+ }
m_24_hour_radio->on_checked = [&](bool) {
m_show_seconds_checkbox->set_enabled(true);
@@ -55,14 +79,14 @@ void ClockSettingsWidget::reset_default_values()
{
m_24_hour_radio->set_checked(true);
m_show_seconds_checkbox->set_checked(true);
- Config::write_string("Taskbar", "Clock", "TimeFormat", "%T");
+ Config::write_string("Taskbar", "Clock", "TimeFormat", time_format_24h_seconds);
}
void ClockSettingsWidget::update_time_format_string()
{
bool show_seconds = m_show_seconds_checkbox->is_checked();
if (m_24_hour_radio->is_checked())
- m_custom_format_input->set_text(show_seconds ? "%T" : "%R");
+ m_custom_format_input->set_text(show_seconds ? time_format_24h_seconds : time_format_24h);
else
- m_custom_format_input->set_text(show_seconds ? "%r" : "%I:%M %p");
+ m_custom_format_input->set_text(show_seconds ? time_format_12h_seconds : time_format_12h);
}