network: Convert NetProxy to GtkTemplate
This whole widget was added to a size group with some elements of the mobile devices. This seems a mistake, but can be added back later if found to be necessary.
This commit is contained in:
parent
7b01c11840
commit
b3e372becd
4 changed files with 34 additions and 60 deletions
|
@ -36,13 +36,11 @@ typedef enum
|
|||
|
||||
struct _NetProxy
|
||||
{
|
||||
NetObject parent;
|
||||
GtkFrame parent;
|
||||
|
||||
GtkBuilder *builder;
|
||||
GtkRadioButton *automatic_radio;
|
||||
GtkDialog *dialog;
|
||||
GtkButton *dialog_button;
|
||||
GtkFrame *main_widget;
|
||||
GtkRadioButton *manual_radio;
|
||||
GtkRadioButton *none_radio;
|
||||
GtkEntry *proxy_ftp_entry;
|
||||
|
@ -62,7 +60,7 @@ struct _NetProxy
|
|||
GSettings *settings;
|
||||
};
|
||||
|
||||
G_DEFINE_TYPE (NetProxy, net_proxy, NET_TYPE_OBJECT)
|
||||
G_DEFINE_TYPE (NetProxy, net_proxy, GTK_TYPE_FRAME)
|
||||
|
||||
static const gchar *
|
||||
panel_get_string_for_value (ProxyMode mode)
|
||||
|
@ -188,30 +186,16 @@ panel_proxy_mode_radio_changed_cb (NetProxy *self, GtkRadioButton *radio)
|
|||
static void
|
||||
show_dialog_cb (NetProxy *self)
|
||||
{
|
||||
gtk_window_set_transient_for (GTK_WINDOW (self->dialog), GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (self->main_widget))));
|
||||
gtk_window_set_transient_for (GTK_WINDOW (self->dialog), GTK_WINDOW (gtk_widget_get_toplevel (GTK_WIDGET (self))));
|
||||
gtk_window_present (GTK_WINDOW (self->dialog));
|
||||
}
|
||||
|
||||
static GtkWidget *
|
||||
net_proxy_get_widget (NetObject *object,
|
||||
GtkSizeGroup *heading_size_group)
|
||||
{
|
||||
NetProxy *self = NET_PROXY (object);
|
||||
|
||||
gtk_size_group_add_widget (heading_size_group, GTK_WIDGET (self->main_widget));
|
||||
|
||||
return GTK_WIDGET (self->main_widget);
|
||||
}
|
||||
|
||||
static void
|
||||
net_proxy_finalize (GObject *object)
|
||||
{
|
||||
NetProxy *self = NET_PROXY (object);
|
||||
|
||||
gtk_widget_destroy (GTK_WIDGET (self->dialog));
|
||||
|
||||
g_clear_object (&self->settings);
|
||||
g_clear_object (&self->builder);
|
||||
|
||||
G_OBJECT_CLASS (net_proxy_parent_class)->finalize (object);
|
||||
}
|
||||
|
@ -220,10 +204,30 @@ static void
|
|||
net_proxy_class_init (NetProxyClass *klass)
|
||||
{
|
||||
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
||||
NetObjectClass *parent_class = NET_OBJECT_CLASS (klass);
|
||||
GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
|
||||
|
||||
object_class->finalize = net_proxy_finalize;
|
||||
parent_class->get_widget = net_proxy_get_widget;
|
||||
|
||||
gtk_widget_class_set_template_from_resource (widget_class, "/org/gnome/control-center/network/network-proxy.ui");
|
||||
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, automatic_radio);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, dialog);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, dialog_button);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, manual_radio);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, none_radio);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, proxy_ftp_entry);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, proxy_http_entry);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, proxy_https_entry);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, proxy_ignore_entry);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, proxy_port_ftp_adjustment);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, proxy_port_http_adjustment);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, proxy_port_https_adjustment);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, proxy_port_socks_adjustment);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, proxy_socks_entry);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, proxy_url_entry);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, proxy_warning_label);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, stack);
|
||||
gtk_widget_class_bind_template_child (widget_class, NetProxy, status_label);
|
||||
}
|
||||
|
||||
static gboolean
|
||||
|
@ -282,36 +286,8 @@ net_proxy_init (NetProxy *self)
|
|||
g_autoptr(GSettings) ftp_settings = NULL;
|
||||
g_autoptr(GSettings) socks_settings = NULL;
|
||||
ProxyMode value;
|
||||
g_autoptr(GError) error = NULL;
|
||||
|
||||
self->builder = gtk_builder_new ();
|
||||
gtk_builder_add_from_resource (self->builder,
|
||||
"/org/gnome/control-center/network/network-proxy.ui",
|
||||
&error);
|
||||
if (error != NULL) {
|
||||
g_warning ("Could not load interface file: %s", error->message);
|
||||
return;
|
||||
}
|
||||
|
||||
self->automatic_radio = GTK_RADIO_BUTTON (gtk_builder_get_object (self->builder, "automatic_radio"));
|
||||
self->dialog = GTK_DIALOG (gtk_builder_get_object (self->builder, "dialog"));
|
||||
self->dialog_button = GTK_BUTTON (gtk_builder_get_object (self->builder, "dialog_button"));
|
||||
self->main_widget = GTK_FRAME (gtk_builder_get_object (self->builder, "main_widget"));
|
||||
self->manual_radio = GTK_RADIO_BUTTON (gtk_builder_get_object (self->builder, "manual_radio"));
|
||||
self->none_radio = GTK_RADIO_BUTTON (gtk_builder_get_object (self->builder, "none_radio"));
|
||||
self->proxy_ftp_entry = GTK_ENTRY (gtk_builder_get_object (self->builder, "proxy_ftp_entry"));
|
||||
self->proxy_http_entry = GTK_ENTRY (gtk_builder_get_object (self->builder, "proxy_http_entry"));
|
||||
self->proxy_https_entry = GTK_ENTRY (gtk_builder_get_object (self->builder, "proxy_https_entry"));
|
||||
self->proxy_ignore_entry = GTK_ENTRY (gtk_builder_get_object (self->builder, "proxy_ignore_entry"));
|
||||
self->proxy_port_ftp_adjustment = GTK_ADJUSTMENT (gtk_builder_get_object (self->builder, "proxy_port_ftp_adjustment"));
|
||||
self->proxy_port_http_adjustment = GTK_ADJUSTMENT (gtk_builder_get_object (self->builder, "proxy_port_http_adjustment"));
|
||||
self->proxy_port_https_adjustment = GTK_ADJUSTMENT (gtk_builder_get_object (self->builder, "proxy_port_https_adjustment"));
|
||||
self->proxy_port_socks_adjustment = GTK_ADJUSTMENT (gtk_builder_get_object (self->builder, "proxy_port_socks_adjustment"));
|
||||
self->proxy_socks_entry = GTK_ENTRY (gtk_builder_get_object (self->builder, "proxy_socks_entry"));
|
||||
self->proxy_url_entry = GTK_ENTRY (gtk_builder_get_object (self->builder, "proxy_url_entry"));
|
||||
self->proxy_warning_label = GTK_LABEL (gtk_builder_get_object (self->builder, "proxy_warning_label"));
|
||||
self->stack = GTK_STACK (gtk_builder_get_object (self->builder, "stack"));
|
||||
self->status_label = GTK_LABEL (gtk_builder_get_object (self->builder, "status_label"));
|
||||
gtk_widget_init_template (GTK_WIDGET (self));
|
||||
|
||||
self->settings = g_settings_new ("org.gnome.system.proxy");
|
||||
g_signal_connect_swapped (self->settings,
|
||||
|
@ -406,5 +382,5 @@ net_proxy_init (NetProxy *self)
|
|||
NetProxy *
|
||||
net_proxy_new (void)
|
||||
{
|
||||
return g_object_new (NET_TYPE_PROXY, NULL);
|
||||
return g_object_new (net_proxy_get_type (), NULL);
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue