display: Make night light a panel page
This introduces a GtkStack to handle the pages; move the current panel to be the "displays" page; and adds the Night Light page as "night-light". A stack switcher was added, as a header widget, to control the stack. https://gitlab.gnome.org/GNOME/gnome-control-center/issues/533
This commit is contained in:
parent
b46aef0cb6
commit
50be7b13c8
2 changed files with 344 additions and 374 deletions
|
@ -75,7 +75,6 @@ struct _CcDisplayPanel
|
||||||
|
|
||||||
CcNightLightPage *night_light_page;
|
CcNightLightPage *night_light_page;
|
||||||
GtkDialog *night_light_dialog;
|
GtkDialog *night_light_dialog;
|
||||||
GSettings *settings_color;
|
|
||||||
|
|
||||||
UpClient *up_client;
|
UpClient *up_client;
|
||||||
gboolean lid_is_closed;
|
gboolean lid_is_closed;
|
||||||
|
@ -104,13 +103,13 @@ struct _CcDisplayPanel
|
||||||
GtkWidget *config_type_switcher_frame;
|
GtkWidget *config_type_switcher_frame;
|
||||||
GtkLabel *current_output_label;
|
GtkLabel *current_output_label;
|
||||||
GtkWidget *display_settings_frame;
|
GtkWidget *display_settings_frame;
|
||||||
GtkLabel *night_light_status_label;
|
|
||||||
GtkSwitch *output_enabled_switch;
|
GtkSwitch *output_enabled_switch;
|
||||||
GtkComboBox *output_selection_combo;
|
GtkComboBox *output_selection_combo;
|
||||||
GtkStack *output_selection_stack;
|
GtkStack *output_selection_stack;
|
||||||
GtkButtonBox *output_selection_two_first;
|
GtkButtonBox *output_selection_two_first;
|
||||||
GtkButtonBox *output_selection_two_second;
|
GtkButtonBox *output_selection_two_second;
|
||||||
HdyComboRow *primary_display_row;
|
HdyComboRow *primary_display_row;
|
||||||
|
GtkWidget *stack_switcher;
|
||||||
};
|
};
|
||||||
|
|
||||||
CC_PANEL_REGISTER (CcDisplayPanel, cc_display_panel)
|
CC_PANEL_REGISTER (CcDisplayPanel, cc_display_panel)
|
||||||
|
@ -428,7 +427,6 @@ cc_display_panel_dispose (GObject *object)
|
||||||
g_clear_object (&self->manager);
|
g_clear_object (&self->manager);
|
||||||
g_clear_object (&self->current_config);
|
g_clear_object (&self->current_config);
|
||||||
g_clear_object (&self->up_client);
|
g_clear_object (&self->up_client);
|
||||||
g_clear_object (&self->settings_color);
|
|
||||||
|
|
||||||
g_cancellable_cancel (self->shell_cancellable);
|
g_cancellable_cancel (self->shell_cancellable);
|
||||||
g_clear_object (&self->shell_cancellable);
|
g_clear_object (&self->shell_cancellable);
|
||||||
|
@ -622,6 +620,14 @@ cc_display_panel_get_help_uri (CcPanel *panel)
|
||||||
return "help:gnome-help/prefs-display";
|
return "help:gnome-help/prefs-display";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GtkWidget *
|
||||||
|
cc_display_panel_get_title_widget (CcPanel *panel)
|
||||||
|
{
|
||||||
|
CcDisplayPanel *self = CC_DISPLAY_PANEL (panel);
|
||||||
|
|
||||||
|
return self->stack_switcher;
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
cc_display_panel_class_init (CcDisplayPanelClass *klass)
|
cc_display_panel_class_init (CcDisplayPanelClass *klass)
|
||||||
{
|
{
|
||||||
|
@ -629,7 +635,10 @@ cc_display_panel_class_init (CcDisplayPanelClass *klass)
|
||||||
CcPanelClass *panel_class = CC_PANEL_CLASS (klass);
|
CcPanelClass *panel_class = CC_PANEL_CLASS (klass);
|
||||||
GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
|
GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
|
||||||
|
|
||||||
|
g_type_ensure (CC_TYPE_NIGHT_LIGHT_PAGE);
|
||||||
|
|
||||||
panel_class->get_help_uri = cc_display_panel_get_help_uri;
|
panel_class->get_help_uri = cc_display_panel_get_help_uri;
|
||||||
|
panel_class->get_title_widget = cc_display_panel_get_title_widget;
|
||||||
|
|
||||||
object_class->constructed = cc_display_panel_constructed;
|
object_class->constructed = cc_display_panel_constructed;
|
||||||
object_class->dispose = cc_display_panel_dispose;
|
object_class->dispose = cc_display_panel_dispose;
|
||||||
|
@ -644,13 +653,14 @@ cc_display_panel_class_init (CcDisplayPanelClass *klass)
|
||||||
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, config_type_single);
|
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, config_type_single);
|
||||||
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, current_output_label);
|
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, current_output_label);
|
||||||
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, display_settings_frame);
|
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, display_settings_frame);
|
||||||
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, night_light_status_label);
|
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, night_light_page);
|
||||||
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, output_enabled_switch);
|
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, output_enabled_switch);
|
||||||
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, output_selection_combo);
|
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, output_selection_combo);
|
||||||
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, output_selection_stack);
|
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, output_selection_stack);
|
||||||
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, output_selection_two_first);
|
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, output_selection_two_first);
|
||||||
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, output_selection_two_second);
|
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, output_selection_two_second);
|
||||||
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, primary_display_row);
|
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, primary_display_row);
|
||||||
|
gtk_widget_class_bind_template_child (widget_class, CcDisplayPanel, stack_switcher);
|
||||||
|
|
||||||
gtk_widget_class_bind_template_callback (widget_class, on_config_type_toggled_cb);
|
gtk_widget_class_bind_template_callback (widget_class, on_config_type_toggled_cb);
|
||||||
gtk_widget_class_bind_template_callback (widget_class, on_night_light_list_box_row_activated_cb);
|
gtk_widget_class_bind_template_callback (widget_class, on_night_light_list_box_row_activated_cb);
|
||||||
|
@ -1132,22 +1142,6 @@ sensor_proxy_vanished_cb (GDBusConnection *connection,
|
||||||
update_has_accel (self);
|
update_has_accel (self);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
|
||||||
night_light_sync_label (GtkWidget *label, GSettings *settings)
|
|
||||||
{
|
|
||||||
gboolean ret = g_settings_get_boolean (settings, "night-light-enabled");
|
|
||||||
gtk_label_set_label (GTK_LABEL (label),
|
|
||||||
/* TRANSLATORS: the state of the night light setting */
|
|
||||||
ret ? _("On") : _("Off"));
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
|
||||||
settings_color_changed_cb (GSettings *settings, gchar *key, GtkWidget *label)
|
|
||||||
{
|
|
||||||
if (g_strcmp0 (key, "night-light-enabled") == 0)
|
|
||||||
night_light_sync_label (label, settings);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void
|
static void
|
||||||
session_bus_ready (GObject *source,
|
session_bus_ready (GObject *source,
|
||||||
GAsyncResult *res,
|
GAsyncResult *res,
|
||||||
|
@ -1222,13 +1216,6 @@ cc_display_panel_init (CcDisplayPanel *self)
|
||||||
0);
|
0);
|
||||||
gtk_cell_renderer_set_visible (renderer, TRUE);
|
gtk_cell_renderer_set_visible (renderer, TRUE);
|
||||||
|
|
||||||
self->night_light_page = cc_night_light_page_new ();
|
|
||||||
self->settings_color = g_settings_new ("org.gnome.settings-daemon.plugins.color");
|
|
||||||
|
|
||||||
g_signal_connect_object (self->settings_color, "changed",
|
|
||||||
G_CALLBACK (settings_color_changed_cb), self->night_light_status_label, 0);
|
|
||||||
night_light_sync_label (GTK_WIDGET (self->night_light_status_label), self->settings_color);
|
|
||||||
|
|
||||||
self->up_client = up_client_new ();
|
self->up_client = up_client_new ();
|
||||||
if (up_client_get_lid_is_present (self->up_client))
|
if (up_client_get_lid_is_present (self->up_client))
|
||||||
{
|
{
|
||||||
|
|
|
@ -33,9 +33,19 @@
|
||||||
<property name="icon_name">video-single-display-symbolic</property>
|
<property name="icon_name">video-single-display-symbolic</property>
|
||||||
<property name="icon_size">3</property>
|
<property name="icon_size">3</property>
|
||||||
</object>
|
</object>
|
||||||
|
<object class="GtkStackSwitcher" id="stack_switcher">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="stack">stack</property>
|
||||||
|
</object>
|
||||||
<template class="CcDisplayPanel" parent="CcPanel">
|
<template class="CcDisplayPanel" parent="CcPanel">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
<property name="can_focus">False</property>
|
<property name="can_focus">False</property>
|
||||||
|
<child>
|
||||||
|
<object class="GtkStack" id="stack">
|
||||||
|
<property name="visible">True</property>
|
||||||
|
<property name="transition-type">crossfade</property>
|
||||||
|
|
||||||
|
<!-- Displays page -->
|
||||||
<child>
|
<child>
|
||||||
<object class="GtkScrolledWindow">
|
<object class="GtkScrolledWindow">
|
||||||
<property name="visible">True</property>
|
<property name="visible">True</property>
|
||||||
|
@ -431,57 +441,30 @@
|
||||||
<property name="position">2</property>
|
<property name="position">2</property>
|
||||||
</packing>
|
</packing>
|
||||||
</child>
|
</child>
|
||||||
<child>
|
|
||||||
<object class="GtkFrame">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="can_focus">False</property>
|
|
||||||
<property name="label_xalign">0</property>
|
|
||||||
<property name="shadow_type">in</property>
|
|
||||||
<child>
|
|
||||||
<object class="GtkListBox">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="can_focus">False</property>
|
|
||||||
<property name="selection_mode">none</property>
|
|
||||||
<signal name="row-activated" handler="on_night_light_list_box_row_activated_cb" swapped="yes"/>
|
|
||||||
<child>
|
|
||||||
<object class="HdyActionRow">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="can_focus">True</property>
|
|
||||||
<property name="selectable">False</property>
|
|
||||||
<property name="title" translatable="yes">Night Light</property>
|
|
||||||
<child type="action">
|
|
||||||
<object class="GtkLabel" id="night_light_status_label">
|
|
||||||
<property name="visible">True</property>
|
|
||||||
<property name="can_focus">False</property>
|
|
||||||
<property name="halign">end</property>
|
|
||||||
<property name="label" translatable="no">-</property>
|
|
||||||
</object>
|
</object>
|
||||||
</child>
|
</child>
|
||||||
</object>
|
</object>
|
||||||
</child>
|
</child>
|
||||||
</object>
|
</object>
|
||||||
</child>
|
</child>
|
||||||
<child type="label_item">
|
|
||||||
<placeholder/>
|
|
||||||
</child>
|
|
||||||
<child internal-child="accessible">
|
|
||||||
<object class="AtkObject">
|
|
||||||
<property name="AtkObject::accessible-name" translatable="yes">Night Light</property>
|
|
||||||
</object>
|
|
||||||
</child>
|
|
||||||
</object>
|
</object>
|
||||||
<packing>
|
<packing>
|
||||||
<property name="expand">False</property>
|
<property name="name">displays</property>
|
||||||
<property name="fill">True</property>
|
<property name="title" translatable="yes">Displays</property>
|
||||||
<property name="position">3</property>
|
|
||||||
</packing>
|
</packing>
|
||||||
</child>
|
</child>
|
||||||
|
|
||||||
|
<!-- Night Light page -->
|
||||||
|
<child>
|
||||||
|
<object class="CcNightLightPage" id="night_light_page">
|
||||||
|
<property name="visible">True</property>
|
||||||
</object>
|
</object>
|
||||||
|
<packing>
|
||||||
|
<property name="name">night-light</property>
|
||||||
|
<property name="title" translatable="yes" comments="This is the redshift functionality where we suppress blue light when the sun has gone down">Night Light</property>
|
||||||
|
</packing>
|
||||||
</child>
|
</child>
|
||||||
</object>
|
|
||||||
</child>
|
|
||||||
</object>
|
|
||||||
</child>
|
|
||||||
</object>
|
</object>
|
||||||
</child>
|
</child>
|
||||||
</template>
|
</template>
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue