From eefd540bf71fd217858a205dce6e8ffb22b47d7b Mon Sep 17 00:00:00 2001 From: Andrea Zagli Date: Thu, 23 May 2013 16:24:16 +0200 Subject: [PATCH] Nell'ufficio visualizzate le persone (closes #546). --- data/organigramma/gui/organigramma.gui | 2166 ++++++++++++------------ src/ufficio.c | 70 +- 2 files changed, 1160 insertions(+), 1076 deletions(-) diff --git a/data/organigramma/gui/organigramma.gui b/data/organigramma/gui/organigramma.gui index 7982b82..91423b0 100644 --- a/data/organigramma/gui/organigramma.gui +++ b/data/organigramma/gui/organigramma.gui @@ -278,6 +278,14 @@ + + + + + + + + @@ -1172,39 +1180,169 @@ True True - + + True + False + 5 + 5 + + + True + True + automatic + automatic + etched-in + + + True + True + lstore_persona_incarichi + False + 0 + + + Da data + + + + 1 + + + + + + + A data + + + + 2 + + + + + + + Descrizione + + + + 3 + + + + + + + + + True + True + 0 + + + + + True + False + 5 + start + + + gtk-new + True + True + True + True + + + False + False + 0 + + + + + gtk-edit + True + True + True + True + + + False + False + 1 + + + + + gtk-delete + True + True + True + True + + + False + False + 2 + + + + + False + True + 1 + + + + + + + True + False + Incarichi + + + 3 + False + + + + True False - 0 - + True False - 12 + 0 - + True False + 5 5 - + True True automatic automatic etched-in - + True True - lstore_persona_incarichi + lstore_persona_nodi False 0 - - Da data + + Tipo - + 1 @@ -1212,10 +1350,10 @@ - - A data + + Nodo - + 2 @@ -1223,16 +1361,27 @@ - - Descrizione + + Da data - + 3 + + + A data + + + + 4 + + + + @@ -1243,13 +1392,13 @@ - + True False 5 start - + gtk-new True True @@ -1263,7 +1412,7 @@ - + gtk-edit True True @@ -1277,7 +1426,7 @@ - + gtk-delete True True @@ -1299,174 +1448,6 @@ - - - - - True - False - <b>Incarichi</b> - True - - - - - - - True - False - Incarichi - - - 3 - False - - - - - True - False - - - True - False - 0 - - - True - False - 12 - - - True - False - 5 - - - True - True - automatic - automatic - etched-in - - - True - True - lstore_persona_nodi - False - 0 - - - Tipo - - - - 1 - - - - - - - Nodo - - - - 2 - - - - - - - Da data - - - - 3 - - - - - - - A data - - - - 4 - - - - - - - - - True - True - 0 - - - - - True - False - 5 - start - - - gtk-new - True - True - True - True - - - False - False - 0 - - - - - gtk-edit - True - True - True - True - - - False - False - 1 - - - - - gtk-delete - True - True - True - True - - - False - False - 2 - - - - - False - True - 1 - - - - - - True @@ -1488,116 +1469,110 @@ False 0 - + True False - 12 + 5 + 5 - + True - False - 5 + True + automatic + automatic + etched-in - + True True - automatic - automatic - etched-in + lstore_persona_nodo_recapiti + False + 0 - - True - True - lstore_persona_nodo_recapiti - False - 0 + + Tipo - - Tipo - - - - 1 - - - + + + 1 + + + + + + Recapito - - Recapito - - - - 2 - - - + + + 2 + + + + + True + True + 0 + + + + + True + False + 5 + start + + + gtk-new + True + True + True + True + - True - True + False + False 0 - + + gtk-edit True - False - 5 - start - - - gtk-new - True - True - True - True - - - False - False - 0 - - - - - gtk-edit - True - True - True - True - - - False - False - 1 - - - - - gtk-delete - True - True - True - True - - - False - False - 2 - - + True + True + True False - True + False 1 + + + gtk-delete + True + True + True + True + + + False + False + 2 + + + + False + True + 1 + @@ -1642,269 +1617,129 @@ False 0 - + True False - 12 + 5 + 5 - + True - False - 5 - - + True + automatic + automatic + etched-in + + True True - automatic - automatic - etched-in + lstore_persona_uffici + False + 0 - - True - True - lstore_persona_uffici - False - 0 - - - Ufficio - - - - 1 - - - - - - - Da data - - - - 2 - - - - + + Ufficio - - A data - - - - 3 - - - + + + 1 + - - - True - True - 0 - - - - - True - False - 5 - start - - - gtk-new - True - True - True - True - - - False - False - 0 - - - - gtk-edit - True - True - True - True + + Da data + + + + 2 + + - - False - False - 1 - - - gtk-delete - True - True - True - True + + A data + + + + 3 + + - - False - False - 2 - - - False - True - 1 - + + True + True + 0 + - - - - - True - False - <b>Uffici</b> - True - - - - - True - True - 0 - - - - - True - False - 0 - - - True - False - 12 - + True False 5 + start - + + gtk-new True True - automatic - automatic - etched-in - - - True - True - lstore_persona_ufficio_recapiti - False - 0 - - - Tipo - - - - 1 - - - - - - - Recapito - - - - 2 - - - - - - + True + True - True - True + False + False 0 - + + gtk-edit True - False - 5 - start - - - gtk-new - True - True - True - True - - - False - False - 0 - - - - - gtk-edit - True - True - True - True - - - False - False - 1 - - - - - gtk-delete - True - True - True - True - - - False - False - 2 - - + True + True + True False - True + False 1 + + + gtk-delete + True + True + True + True + + + False + False + 2 + + + + False + True + 1 + - + True False - <b>Recapiti</b> + <b>Uffici</b> True @@ -1912,59 +1747,39 @@ True True - 1 + 0 - - - 2 - - - - - True - False - Uffici - - - 2 - False - - - - - True - False - 0 - + True False - 12 + 0 - + True False + 5 5 - + True True automatic automatic etched-in - + True True - lstore_persona_recapiti + lstore_persona_ufficio_recapiti False 0 - + Tipo - + 1 @@ -1972,10 +1787,10 @@ - + Recapito - + 2 @@ -1992,13 +1807,13 @@ - + True False 5 start - + gtk-new True True @@ -2012,7 +1827,7 @@ - + gtk-edit True True @@ -2026,7 +1841,7 @@ - + gtk-delete True True @@ -2048,15 +1863,142 @@ + + + True + False + <b>Recapiti</b> + True + + + + + True + True + 1 + + + + + 2 + + + + + True + False + Uffici + + + 2 + False + + + + + True + False + 5 + 5 + + + True + True + automatic + automatic + etched-in + + + True + True + lstore_persona_recapiti + False + 0 + + + Tipo + + + + 1 + + + + + + + Recapito + + + + 2 + + + + + + + + True + True + 0 + - - + + True False - <b>Recapiti</b> - True + 5 + start + + + gtk-new + True + True + True + True + + + False + False + 0 + + + + + gtk-edit + True + True + True + True + + + False + False + 1 + + + + + gtk-delete + True + True + True + True + + + False + False + 2 + + + + False + True + 1 + @@ -5078,105 +5020,99 @@ False 0 - + True False - 12 + 5 + 5 - + True - False - 5 + True + automatic + automatic + etched-in - + True True - automatic - automatic - etched-in + lstore_struttura_indirizzi + False + 0 - - True - True - lstore_struttura_indirizzi - False - 0 + + Indirizzo - - Indirizzo - - - - 1 - - - + + + 1 + + + + + True + True + 0 + + + + + True + False + 5 + start + + + gtk-new + True + True + True + True + - True - True + False + False 0 - + + gtk-edit True - False - 5 - start - - - gtk-new - True - True - True - True - - - False - False - 0 - - - - - gtk-edit - True - True - True - True - - - False - False - 1 - - - - - gtk-delete - True - True - True - True - - - False - False - 2 - - + True + True + True False - True + False 1 + + + gtk-delete + True + True + True + True + + + False + False + 2 + + + + False + True + 1 + @@ -5404,6 +5340,7 @@ 2 3 4 + GTK_FILL @@ -7324,7 +7261,7 @@ True False - 9 + 8 2 5 5 @@ -7437,575 +7374,310 @@ - + True False 0 - + True False - 12 + 5 + 5 - + True - False - 5 + True + automatic + automatic + etched-in - + True True - automatic - automatic - etched-in + lstore_ufficio_nodi + False + 0 - - True - True - lstore_ufficio_recapiti + + Tipo - - Tipo - - - - 0 - - - + + + 0 + + + + + + Nodo - - Recapito - - - - 2 - - - + + + 2 + + + + + True + True + 0 + + + + + True + False + 5 + start + + + gtk-new + True + True + True + True + - True - True + False + False 0 - + + gtk-edit True - False - 5 - start - - - gtk-new - True - True - True - True - - - False - False - 0 - - - - - gtk-edit - True - True - True - True - - - False - False - 1 - - - - - gtk-delete - True - True - True - True - - - False - False - 2 - - + True + True + True False - True + False 1 + + + gtk-delete + True + True + True + True + + + False + False + 2 + + + + False + True + 1 + - + True False - <b>Recapiti</b> + <b>Nodi superiori</b> True 2 - 7 - 8 + 1 + 2 - + True False 0 - + True False - 12 + 5 + 5 - + True - False - 5 + True + automatic + automatic + etched-in - + True True - automatic - automatic - etched-in + lstore_ufficio_stanze + False + 0 - - True - True - lstore_ufficio_nodi + + Piano - - Tipo - - - - 0 - - - + + + 1 + + + + + + Da stanza - - Nodo - - - - 2 - - - + + + 2 + + + + + + + A stanza + + + + 3 + + + + + True + True + 0 + + + + + True + False + 5 + start + + + gtk-new + True + True + True + True + - True - True + False + False 0 - + + gtk-edit True - False - 5 - start - - - gtk-new - True - True - True - True - - - False - False - 0 - - - - - gtk-edit - True - True - True - True - - - False - False - 1 - - - - - gtk-delete - True - True - True - True - - - False - False - 2 - - + True + True + True False - True + False 1 + + + gtk-delete + True + True + True + True + + + False + False + 2 + + + + False + True + 1 + - + True False - <b>Nodi superiori</b> + <b>Stanze</b> True 2 - 1 - 2 + 4 + 5 - + True False - 0 + 5 + + + True + True + False + ● + True + False + False + True + True + + + True + True + 0 + + - + + ... True - False - 12 - - - True - False - 5 - - - True - True - automatic - automatic - etched-in - - - True - True - lstore_ufficio_orari - False - 0 - - - Orario - - - - 1 - - - - - - - - - True - True - 0 - - - - - True - False - 5 - start - - - gtk-new - True - True - True - True - - - False - False - 0 - - - - - gtk-edit - True - True - True - True - - - False - False - 1 - - - - - gtk-delete - True - True - True - True - - - False - False - 2 - - - - - False - True - 1 - - - - - - - - - True - False - <b>Orari</b> - True - - - - - 2 - 8 - 9 - - - - - True - False - 0 - - - True - False - 12 - - - True - False - 5 - - - True - True - automatic - automatic - etched-in - - - True - True - lstore_ufficio_stanze - False - 0 - - - Piano - - - - 1 - - - - - - - Da stanza - - - - 2 - - - - - - - A stanza - - - - 3 - - - - - - - - - True - True - 0 - - - - - True - False - 5 - start - - - gtk-new - True - True - True - True - - - False - False - 0 - - - - - gtk-edit - True - True - True - True - - - False - False - 1 - - - - - gtk-delete - True - True - True - True - - - False - False - 2 - - - - - False - True - 1 - - - - - - - - - True - False - <b>Stanze</b> - True - - - - - 2 - 4 - 5 - - - - - True - False - 5 - - - True - True - False - ● - True - False - False - True - True - - - True - True - 0 - - - - - ... - True - True - True - - - False - True - 1 - - - - + True + True + + + False + True + 1 + + + + False lbl_id_strutture @@ -8095,6 +7767,358 @@ GTK_FILL + + + True + True + + + True + False + 5 + 5 + + + True + True + automatic + automatic + etched-in + + + True + True + lstore_ufficio_recapiti + False + 0 + + + Tipo + + + + 0 + + + + + + + Recapito + + + + 2 + + + + + + + + + True + True + 0 + + + + + True + False + 5 + start + + + gtk-new + True + True + True + True + + + False + False + 0 + + + + + gtk-edit + True + True + True + True + + + False + False + 1 + + + + + gtk-delete + True + True + True + True + + + False + False + 2 + + + + + False + True + 1 + + + + + + + True + False + Recapiti + + + False + + + + + True + False + 5 + 5 + + + True + True + automatic + automatic + etched-in + + + True + True + lstore_ufficio_orari + False + 0 + + + Orario + + + + 1 + + + + + + + + + True + True + 0 + + + + + True + False + 5 + start + + + gtk-new + True + True + True + True + + + False + False + 0 + + + + + gtk-edit + True + True + True + True + + + False + False + 1 + + + + + gtk-delete + True + True + True + True + + + False + False + 2 + + + + + False + True + 1 + + + + + 1 + + + + + True + False + Orari + + + 1 + False + + + + + True + False + 5 + 5 + + + True + True + automatic + automatic + etched-in + + + True + True + lstore_ufficio_persone + False + True + 0 + + + Nome + + + + 1 + + + + + + + + + True + True + 0 + + + + + True + False + 5 + start + + + gtk-new + True + True + True + True + + + False + False + 0 + + + + + gtk-edit + True + True + True + True + + + False + False + 1 + + + + + gtk-delete + True + True + True + True + + + False + False + 2 + + + + + False + True + 1 + + + + + 2 + + + + + True + False + Persone + + + 2 + False + + + + + 2 + 7 + 8 + + True diff --git a/src/ufficio.c b/src/ufficio.c index c297a62..8296353 100644 --- a/src/ufficio.c +++ b/src/ufficio.c @@ -23,6 +23,7 @@ #include #include +#include #include #include "ufficio.h" @@ -43,6 +44,7 @@ static void organigramma_ufficio_carica_nodi (OrganigrammaUfficio *ufficio); static void organigramma_ufficio_carica_stanze (OrganigrammaUfficio *ufficio); static void organigramma_ufficio_carica_recapiti (OrganigrammaUfficio *ufficio); static void organigramma_ufficio_carica_orari (OrganigrammaUfficio *ufficio); +static void organigramma_ufficio_carica_persone (OrganigrammaUfficio *ufficio); static void organigramma_ufficio_nodo_modifica (OrganigrammaUfficio *ufficio); static void organigramma_ufficio_stanza_modifica (OrganigrammaUfficio *ufficio); @@ -142,7 +144,8 @@ enum LSTORE_NODI, LSTORE_STANZE, LSTORE_RECAPITI, - LSTORE_ORARI + LSTORE_ORARI, + LSTORE_PERSONE }; enum @@ -174,6 +177,14 @@ enum ORARI_COL_ORARIO }; +enum +{ + PERSONE_COL_ID, + PERSONE_COL_NOME, + PERSONE_COL_DA_DATA, + PERSONE_COL_A_DATA +}; + typedef struct _OrganigrammaUfficioPrivate OrganigrammaUfficioPrivate; struct _OrganigrammaUfficioPrivate { @@ -189,6 +200,7 @@ struct _OrganigrammaUfficioPrivate GtkTreeSelection *sel_stanze; GtkTreeSelection *sel_recapiti; GtkTreeSelection *sel_orari; + GtkTreeSelection *sel_persone; gint id; }; @@ -249,10 +261,13 @@ OrganigrammaUfficio error = NULL; gtk_builder_add_objects_from_file (priv->commons->gtkbuilder, priv->commons->guifile, g_strsplit ("lstore_ufficio_nodi" - "|lstore_ufficio_stanze" - "|lstore_ufficio_recapiti" - "|lstore_ufficio_orari" - "|w_ufficio", "|", -1), + "|lstore_ufficio_stanze" + "|lstore_ufficio_recapiti" + "|lstore_ufficio_orari" + "|lstore_ufficio_persone" + "|w_ufficio", + "|", + -1), &error); if (error != NULL) { @@ -272,12 +287,14 @@ OrganigrammaUfficio "lstore_ufficio_stanze", "lstore_ufficio_recapiti", "lstore_ufficio_orari", + "lstore_ufficio_persone", NULL); priv->sel_nodi = gtk_tree_view_get_selection (GTK_TREE_VIEW (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview7"))); priv->sel_stanze = gtk_tree_view_get_selection (GTK_TREE_VIEW (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview23"))); priv->sel_recapiti = gtk_tree_view_get_selection (GTK_TREE_VIEW (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview6"))); priv->sel_orari = gtk_tree_view_get_selection (GTK_TREE_VIEW (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview10"))); + priv->sel_persone = gtk_tree_view_get_selection (GTK_TREE_VIEW (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview24"))); g_signal_connect (priv->w, "delete-event", G_CALLBACK (organigramma_ufficio_on_w_organigramma_ufficio_delete_event), (gpointer)a); @@ -414,6 +431,7 @@ organigramma_ufficio_carica (OrganigrammaUfficio *ufficio) organigramma_ufficio_carica_stanze (ufficio); organigramma_ufficio_carica_recapiti (ufficio); organigramma_ufficio_carica_orari (ufficio); + organigramma_ufficio_carica_persone (ufficio); } } @@ -633,6 +651,48 @@ organigramma_ufficio_carica_orari (OrganigrammaUfficio *ufficio) } } +static void +organigramma_ufficio_carica_persone (OrganigrammaUfficio *ufficio) +{ + gchar *sql; + GdaDataModel *dm; + guint row; + guint rows; + + OrganigrammaUfficioPrivate *priv = ORGANIGRAMMA_UFFICIO_GET_PRIVATE (ufficio); + + gtk_list_store_clear (GTK_LIST_STORE (priv->objects[LSTORE_PERSONE])); + + sql = g_strdup_printf ("SELECT p.id, p.cognome || ' ' || p.nome AS cognome_nome," + " pi.da_data, pi.a_data" + " FROM persona_uffici AS pi" + " INNER JOIN persone AS p ON pi.id_persone = p.id" + " WHERE pi.id_uffici = %d" + " AND pi.status <> 'E'" + " ORDER BY p.cognome, p.nome, pi.da_data, pi.a_data", + priv->id); + dm = gdaex_query (priv->commons->gdaex, sql); + g_free (sql); + if (dm != NULL) + { + GtkTreeIter iter; + + rows = gda_data_model_get_n_rows (dm); + for (row = 0; row < rows; row++) + { + gtk_list_store_append (GTK_LIST_STORE (priv->objects[LSTORE_PERSONE]), &iter); + gtk_list_store_set (GTK_LIST_STORE (priv->objects[LSTORE_PERSONE]), &iter, + PERSONE_COL_ID, gdaex_data_model_get_field_value_integer_at (dm, row, "id"), + PERSONE_COL_NOME, gdaex_data_model_get_field_value_stringify_at (dm, row, "cognome_nome"), + PERSONE_COL_DA_DATA, gtk_form_field_datetime_get_str_from_tm (gdaex_data_model_get_field_value_tm_at (dm, row, "da_data"), "%d/%m/%Y"), + PERSONE_COL_A_DATA, gtk_form_field_datetime_get_str_from_tm (gdaex_data_model_get_field_value_tm_at (dm, row, "a_data"), "%d/%m/%Y"), + -1); + } + + g_object_unref (dm); + } +} + static void organigramma_ufficio_nodo_modifica (OrganigrammaUfficio *ufficio) { -- 2.49.0