From: Andrea Zagli Date: Sun, 13 Nov 2016 11:04:04 +0000 (+0100) Subject: Tolta la combobox posizione economica in persona incarico (refs #645 #646). X-Git-Url: https://saetta.ns0.it/gitweb?a=commitdiff_plain;h=5cc3c61afa0b9923802dd200c55d9024df5dfa55;p=solipa%2Forganigramma Tolta la combobox posizione economica in persona incarico (refs #645 #646). --- diff --git a/data/organigramma/form/persona_incarico.form b/data/organigramma/form/persona_incarico.form index 158f336..10bd4d4 100644 --- a/data/organigramma/form/persona_incarico.form +++ b/data/organigramma/form/persona_incarico.form @@ -32,11 +32,14 @@ - - 0 - - SELECT id, nome FROM posizioni_economiche WHERE status <> 'E' ORDER BY nome - + + + + SELECT a.nome + FROM posizioni_economiche AS a + WHERE a.id = ##key0::gint + + diff --git a/data/organigramma/gui/organigramma.gui b/data/organigramma/gui/organigramma.gui index 5fc9e88..b707f15 100644 --- a/data/organigramma/gui/organigramma.gui +++ b/data/organigramma/gui/organigramma.gui @@ -5077,23 +5077,6 @@ 9 - - - True - False - True - - - - 1 - - - - - 1 - 2 - - True @@ -5251,6 +5234,16 @@ 3 + + + True + False + + + 1 + 2 + + True diff --git a/src/personaincarico.c b/src/personaincarico.c index a6bf201..f356878 100644 --- a/src/personaincarico.c +++ b/src/personaincarico.c @@ -30,6 +30,7 @@ #include "personaincarico.h" #include "nodi.h" +#include "posizionieconomiche.h" #include "tipiprestazione.h" #include "tipirapportolavoro.h" #include "profiliprofessionali.h" @@ -56,11 +57,14 @@ static gboolean organigramma_persona_incarico_on_w_organigramma_persona_incarico gpointer user_data); static void organigramma_persona_incarico_on_tipo_rapporto_lavoro_selezionato (gpointer instance, guint id, gpointer user_data); +static void organigramma_persona_incarico_on_posizione_economica_selezionato (gpointer instance, guint id, gpointer user_data); static void organigramma_persona_incarico_on_tipo_prestazione_selezionato (gpointer instance, guint id, gpointer user_data); static void organigramma_persona_incarico_on_profilo_professionale_selezionato (gpointer instance, guint id, gpointer user_data); static void organigramma_persona_incarico_on_btn_ricerca_tipo_rapporto_lavoro_clicked (GtkButton *button, gpointer user_data); +static void organigramma_persona_incarico_on_btn_ricerca_posizione_economica_clicked (GtkButton *button, + gpointer user_data); static void organigramma_persona_incarico_on_btn_ricerca_tipo_prestazione_clicked (GtkButton *button, gpointer user_data); static void organigramma_persona_incarico_on_btn_ricerca_profilo_professionale_clicked (GtkButton *button, @@ -153,9 +157,7 @@ OrganigrammaPersonaIncarico error = NULL; gtk_builder_add_objects_from_file (priv->commons->gtkbuilder, priv->commons->guifile, - g_strsplit ( - "lstore_posizioni_economiche" - "|w_persona_incarico", "|", -1), + g_strsplit ("w_persona_incarico", "|", -1), &error); if (error != NULL) { @@ -179,6 +181,8 @@ OrganigrammaPersonaIncarico g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "gtkformdecoder2"), "btn-browse-clicked", G_CALLBACK (organigramma_persona_incarico_on_btn_ricerca_tipo_rapporto_lavoro_clicked), (gpointer)a); + g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "gtkformdecoder5"), + "btn-browse-clicked", G_CALLBACK (organigramma_persona_incarico_on_btn_ricerca_posizione_economica_clicked), (gpointer)a); g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "gtkformdecoder4"), "btn-browse-clicked", G_CALLBACK (organigramma_persona_incarico_on_btn_ricerca_tipo_prestazione_clicked), (gpointer)a); g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "gtkformdecoder3"), @@ -368,6 +372,17 @@ organigramma_persona_incarico_on_tipo_rapporto_lavoro_selezionato (gpointer inst g_strdup_printf ("%d", id)); } +static void +organigramma_persona_incarico_on_posizione_economica_selezionato (gpointer instance, guint id, gpointer user_data) +{ + OrganigrammaPersonaIncarico *ia = (OrganigrammaPersonaIncarico *)user_data; + + OrganigrammaPersonaIncaricoPrivate *priv = ORGANIGRAMMA_PERSONA_INCARICO_GET_PRIVATE (ia); + + gtk_form_widget_set_value_stringify (gtk_form_get_form_widget_from_name (priv->form, "gtkformdecoder5"), + g_strdup_printf ("%d", id)); +} + static void organigramma_persona_incarico_on_tipo_prestazione_selezionato (gpointer instance, guint id, gpointer user_data) { @@ -409,6 +424,25 @@ organigramma_persona_incarico_on_btn_ricerca_tipo_rapporto_lavoro_clicked (GtkBu gtk_widget_show (w); } +static void +organigramma_persona_incarico_on_btn_ricerca_posizione_economica_clicked (GtkButton *button, + gpointer user_data) +{ + GtkWidget *w; + + OrganigrammaPersonaIncarico *ia = (OrganigrammaPersonaIncarico *)user_data; + OrganigrammaPersonaIncaricoPrivate *priv = ORGANIGRAMMA_PERSONA_INCARICO_GET_PRIVATE (ia); + + OrganigrammaPosizioniEconomiche *c = organigramma_posizioni_economiche_new (priv->commons, TRUE); + + g_signal_connect (G_OBJECT (c), "selezionato", + G_CALLBACK (organigramma_persona_incarico_on_posizione_economica_selezionato), user_data); + + w = organigramma_posizioni_economiche_get_widget (c); + gtk_window_set_transient_for (GTK_WINDOW (w), GTK_WINDOW (priv->w)); + gtk_widget_show (w); +} + static void organigramma_persona_incarico_on_btn_ricerca_tipo_prestazione_clicked (GtkButton *button, gpointer user_data)