From: Andrea Zagli Date: Thu, 8 Dec 2016 09:26:20 +0000 (+0100) Subject: Tolta la combobox tipo recapito in persona recapito (closes #645 refs #646). X-Git-Url: https://saetta.ns0.it/gitweb?a=commitdiff_plain;h=7ebfcfc2a3425c5c3934efa8f8363f9ffaaaed4d;p=solipa%2Forganigramma Tolta la combobox tipo recapito in persona recapito (closes #645 refs #646). --- diff --git a/data/organigramma/form/persona_recapito.form b/data/organigramma/form/persona_recapito.form index 8bb7d19..993b2fe 100644 --- a/data/organigramma/form/persona_recapito.form +++ b/data/organigramma/form/persona_recapito.form @@ -15,11 +15,14 @@ - - 0 - - SELECT id, nome FROM tipi_recapito WHERE status <> 'E' ORDER BY nome - + + + + SELECT a.nome + FROM tipi_recapito AS a + WHERE a.id = ##key0::gint + + t diff --git a/data/organigramma/gui/organigramma.gui b/data/organigramma/gui/organigramma.gui index e599634..8458403 100644 --- a/data/organigramma/gui/organigramma.gui +++ b/data/organigramma/gui/organigramma.gui @@ -5745,23 +5745,6 @@ 1 - - - True - False - True - - - - 1 - - - - - 1 - 0 - - True @@ -5809,6 +5792,16 @@ 4 + + + True + False + + + 1 + 0 + + True diff --git a/src/personarecapito.c b/src/personarecapito.c index 03a4999..5ecb8be 100644 --- a/src/personarecapito.c +++ b/src/personarecapito.c @@ -25,9 +25,11 @@ #include #include +#include #include #include "personarecapito.h" +#include "tipirecapito.h" static void organigramma_persona_recapito_class_init (OrganigrammaPersonaRecapitoClass *klass); static void organigramma_persona_recapito_init (OrganigrammaPersonaRecapito *organigramma_persona_recapito); @@ -35,6 +37,8 @@ static void organigramma_persona_recapito_init (OrganigrammaPersonaRecapito *org static void organigramma_persona_recapito_carica (OrganigrammaPersonaRecapito *organigramma_persona_recapito); static void organigramma_persona_recapito_salva (OrganigrammaPersonaRecapito *organigramma_persona_recapito, gboolean chiudi); +static void organigramma_persona_recapito_on_tipo_recapito_selezionato (gpointer instance, guint id, gpointer user_data); + static gboolean organigramma_persona_recapito_conferma_chiusura (OrganigrammaPersonaRecapito *organigramma_persona_recapito); static void organigramma_persona_recapito_set_property (GObject *object, @@ -50,6 +54,9 @@ static gboolean organigramma_persona_recapito_on_w_organigramma_persona_recapito GdkEvent *event, gpointer user_data); +static void organigramma_persona_recapito_on_btn_tipo_recapito_clicked (GtkButton *button, + gpointer user_data); + static void organigramma_persona_recapito_on_btn_annulla_clicked (GtkButton *button, gpointer user_data); static void organigramma_persona_recapito_on_btn_salva_clicked (GtkButton *button, @@ -159,6 +166,9 @@ OrganigrammaPersonaRecapito g_signal_connect (priv->w, "delete-event", G_CALLBACK (organigramma_persona_recapito_on_w_organigramma_persona_recapito_delete_event), (gpointer)a); + g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "gtkformdecoder10"), + "btn-browse-clicked", G_CALLBACK (organigramma_persona_recapito_on_btn_tipo_recapito_clicked), (gpointer)a); + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button87")), "clicked", G_CALLBACK (organigramma_persona_recapito_on_btn_annulla_clicked), (gpointer)a); g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button88")), @@ -326,6 +336,16 @@ organigramma_persona_recapito_conferma_chiusura (OrganigrammaPersonaRecapito *or } /* CALLBACK */ +static void +organigramma_persona_recapito_on_tipo_recapito_selezionato (gpointer instance, guint id, gpointer user_data) +{ + OrganigrammaPersonaRecapito *f = (OrganigrammaPersonaRecapito *)user_data; + OrganigrammaPersonaRecapitoPrivate *priv = ORGANIGRAMMA_PERSONA_RECAPITO_GET_PRIVATE (f); + + gtk_form_widget_set_value_stringify (gtk_form_get_form_widget_from_name (priv->form, "gtkformdecoder10"), + g_strdup_printf ("%d", id)); +} + static gboolean organigramma_persona_recapito_on_w_organigramma_persona_recapito_delete_event (GtkWidget *widget, GdkEvent *event, @@ -352,6 +372,25 @@ organigramma_persona_recapito_on_btn_salva_clicked (GtkButton *button, organigramma_persona_recapito_salva ((OrganigrammaPersonaRecapito *)user_data, FALSE); } +static void +organigramma_persona_recapito_on_btn_tipo_recapito_clicked (GtkButton *button, + gpointer user_data) +{ + GtkWidget *w; + + OrganigrammaPersonaRecapito *rf = (OrganigrammaPersonaRecapito *)user_data; + OrganigrammaPersonaRecapitoPrivate *priv = ORGANIGRAMMA_PERSONA_RECAPITO_GET_PRIVATE (rf); + + OrganigrammaTipiRecapito *c = organigramma_tipi_recapito_new (priv->commons, TRUE); + + g_signal_connect (G_OBJECT (c), "selezionato", + G_CALLBACK (organigramma_persona_recapito_on_tipo_recapito_selezionato), user_data); + + w = organigramma_tipi_recapito_get_widget (c); + gtk_window_set_transient_for (GTK_WINDOW (w), GTK_WINDOW (priv->w)); + gtk_widget_show (w); +} + static void organigramma_persona_recapito_on_btn_salvaechiudi_clicked (GtkButton *button, gpointer user_data)