Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Expose prefer dark schedule settings #85

Merged
merged 13 commits into from
Jan 31, 2024
18 changes: 18 additions & 0 deletions data/io.elementary.SettingsDaemon.AccountsService.xml
Original file line number Diff line number Diff line change
Expand Up @@ -155,5 +155,23 @@
<property name="NightLightTemperature" type="u" access="readwrite">
<annotation name="org.freedesktop.Accounts.DefaultValue" value="4500"/>
</property>

<!-- Prefer dark schedule-->

<property name="PreferDarkSchedule" type="i" access="readwrite">
<annotation name="org.freedesktop.Accounts.DefaultValue" value="0"/>
</property>

<property name="PreferDarkLastCoordinates" type="(dd)" access="readwrite">
lenemter marked this conversation as resolved.
Show resolved Hide resolved
<annotation name="org.freedesktop.Accounts.DefaultValue" value="(91.0, 181.0)"/>
</property>

<property name="PreferDarkScheduleFrom" type="d" access="readwrite">
<annotation name="org.freedesktop.Accounts.DefaultValue" value="20"/>
</property>

<property name="PreferDarkScheduleTo" type="d" access="readwrite">
<annotation name="org.freedesktop.Accounts.DefaultValue" value="6"/>
</property>
</interface>
</node>
18 changes: 12 additions & 6 deletions src/AccountsService.vala
Original file line number Diff line number Diff line change
Expand Up @@ -20,6 +20,11 @@

[DBus (name = "io.elementary.SettingsDaemon.AccountsService")]
public interface SettingsDaemon.AccountsService : Object {
public struct Coordinates {
public double latitude;
public double longitude;
}

/* Keyboard */
public struct KeyboardLayout {
public string backend;
Expand Down Expand Up @@ -64,14 +69,15 @@ public interface SettingsDaemon.AccountsService : Object {
public abstract string monospace_font_name { owned get; set; }
public abstract bool orientation_lock { get; set; }

/* Night Light */
public struct Coordinates {
lenemter marked this conversation as resolved.
Show resolved Hide resolved
public double latitude;
public double longitude;
}
/* Prefer Dark Schedule (part of interface settings)*/
/* Last coordinates are reused for Night Light settings */
public abstract Coordinates last_coordinates { get; set; }
public abstract int prefer_dark_schedule { get; set; }
public abstract double prefer_dark_schedule_from { get; set; }
public abstract double prefer_dark_schedule_to { get; set; }

/* Night Light */
public abstract bool night_light_enabled { get; set; }
public abstract Coordinates night_light_last_coordinates { get; set; }
public abstract bool night_light_schedule_automatic { get; set; }
public abstract double night_light_schedule_from { get; set; }
public abstract double night_light_schedule_to { get; set; }
Expand Down
34 changes: 34 additions & 0 deletions src/Backends/InterfaceSettings.vala
Original file line number Diff line number Diff line change
Expand Up @@ -33,13 +33,18 @@ public class SettingsDaemon.Backends.InterfaceSettings : GLib.Object {
private const string FONT_NAME = "font-name";
private const string MONOSPACE_FONT_NAME = "monospace-font-name";

private const string LAST_COORDINATES = "last-coordinates";
private const string ORIENTATION_LOCK = "orientation-lock";
private const string PREFER_DARK_SCHEDULE = "prefer-dark-schedule";
private const string PREFER_DARK_SCHEDULE_FROM = "prefer-dark-schedule-from";
private const string PREFER_DARK_SCHEDULE_TO = "prefer-dark-schedule-to";

public unowned AccountsService accounts_service { get; construct; }
public unowned DisplayManager.AccountsService display_manager_accounts_service { get; construct; }

private GLib.Settings interface_settings;
private GLib.Settings background_settings;
private GLib.Settings settings_daemon_settings;
private GLib.Settings touchscreen_settings;

public InterfaceSettings (AccountsService accounts_service, DisplayManager.AccountsService display_manager_accounts_service) {
Expand All @@ -52,6 +57,7 @@ public class SettingsDaemon.Backends.InterfaceSettings : GLib.Object {
construct {
interface_settings = new GLib.Settings ("org.gnome.desktop.interface");
background_settings = new GLib.Settings ("org.gnome.desktop.background");
settings_daemon_settings = new GLib.Settings ("io.elementary.settings-daemon.prefers-color-scheme");
touchscreen_settings = new GLib.Settings ("org.gnome.settings-daemon.peripherals.touchscreen");

sync_gsettings_to_accountsservice ();
Expand Down Expand Up @@ -82,6 +88,15 @@ public class SettingsDaemon.Backends.InterfaceSettings : GLib.Object {
}
});

settings_daemon_settings.changed.connect ((key) => {
if (key == LAST_COORDINATES ||
key == PREFER_DARK_SCHEDULE ||
key == PREFER_DARK_SCHEDULE_FROM ||
key == PREFER_DARK_SCHEDULE_TO) {
sync_gsettings_to_accountsservice ();
}
});

touchscreen_settings.changed.connect (sync_gsettings_to_accountsservice);
}

Expand All @@ -100,6 +115,25 @@ public class SettingsDaemon.Backends.InterfaceSettings : GLib.Object {
accounts_service.font_name = interface_settings.get_string (FONT_NAME);
accounts_service.monospace_font_name = interface_settings.get_string (MONOSPACE_FONT_NAME);

var last_coordinates_value = settings_daemon_settings.get_value (LAST_COORDINATES);
if (last_coordinates_value.is_of_type (GLib.VariantType.TUPLE)) {
double latitude;
double longitude;

last_coordinates_value.@get ("(dd)", out latitude, out longitude);

accounts_service.last_coordinates = AccountsService.Coordinates () {
latitude = latitude,
longitude = longitude
};
} else {
warning ("Unknown prefer dark coordinates type, unable to save to AccountsService");
}

accounts_service.prefer_dark_schedule = settings_daemon_settings.get_enum (PREFER_DARK_SCHEDULE);
accounts_service.prefer_dark_schedule_from = settings_daemon_settings.get_double (PREFER_DARK_SCHEDULE_FROM);
accounts_service.prefer_dark_schedule_to = settings_daemon_settings.get_double (PREFER_DARK_SCHEDULE_TO);

accounts_service.orientation_lock = touchscreen_settings.get_boolean (ORIENTATION_LOCK);
}

Expand Down
18 changes: 0 additions & 18 deletions src/Backends/NightLightSettings.vala
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,6 @@
public class SettingsDaemon.Backends.NightLightSettings : GLib.Object {
private const string NIGHT_LIGHT_SCHEMA = "org.gnome.settings-daemon.plugins.color";
private const string NIGHT_LIGHT_ENABLED = "night-light-enabled";
private const string NIGHT_LIGHT_LAST_COORDINATES = "night-light-last-coordinates";
private const string NIGHT_LIGHT_SCHEDULE_AUTOMATIC = "night-light-schedule-automatic";
private const string NIGHT_LIGHT_SCHEDULE_FROM = "night-light-schedule-from";
private const string NIGHT_LIGHT_SCHEDULE_TO = "night-light-schedule-to";
Expand All @@ -33,7 +32,6 @@

night_light_settings.changed.connect ((key) => {
if (key == NIGHT_LIGHT_ENABLED ||
key == NIGHT_LIGHT_LAST_COORDINATES ||
key == NIGHT_LIGHT_SCHEDULE_AUTOMATIC ||
key == NIGHT_LIGHT_SCHEDULE_FROM ||
key == NIGHT_LIGHT_SCHEDULE_TO ||
Expand All @@ -45,22 +43,6 @@

private void sync_gsettings_to_accountsservice () {
accounts_service.night_light_enabled = night_light_settings.get_boolean (NIGHT_LIGHT_ENABLED);

var last_coordinates_value = night_light_settings.get_value (NIGHT_LIGHT_LAST_COORDINATES);
if (last_coordinates_value.is_of_type (GLib.VariantType.TUPLE)) {
double latitude;
double longitude;

last_coordinates_value.@get ("(dd)", out latitude, out longitude);

accounts_service.night_light_last_coordinates = AccountsService.Coordinates () {
latitude = latitude,
longitude = longitude
};
} else {
warning ("Unknown night light coordinates type, unable to save to AccountsService");
}

accounts_service.night_light_schedule_automatic = night_light_settings.get_boolean (NIGHT_LIGHT_SCHEDULE_AUTOMATIC);
accounts_service.night_light_schedule_from = night_light_settings.get_double (NIGHT_LIGHT_SCHEDULE_FROM);
accounts_service.night_light_schedule_to = night_light_settings.get_double (NIGHT_LIGHT_SCHEDULE_TO);
Expand Down