From 8a9c5f97f68f7af1e4d560d472d426bb3565d923 Mon Sep 17 00:00:00 2001 From: Andrea Zagli Date: Mon, 16 Aug 2010 11:23:06 +0200 Subject: [PATCH] Gestione indirizzi strutture. --- data/organigramma/form/Makefile.am | 1 + .../form/struttura_indirizzo.form | 44 ++ data/organigramma/gui/organigramma.gui | 342 +++++++++++++++- docs/organigramma.sql | 84 ++-- src/Makefile.am | 2 + src/struttura.c | 222 +++++++++- src/strutturaindirizzo.c | 386 ++++++++++++++++++ src/strutturaindirizzo.h | 65 +++ 8 files changed, 1106 insertions(+), 40 deletions(-) create mode 100644 data/organigramma/form/struttura_indirizzo.form create mode 100644 src/strutturaindirizzo.c create mode 100644 src/strutturaindirizzo.h diff --git a/data/organigramma/form/Makefile.am b/data/organigramma/form/Makefile.am index 4857797..6d086ac 100644 --- a/data/organigramma/form/Makefile.am +++ b/data/organigramma/form/Makefile.am @@ -3,6 +3,7 @@ formdir = $(datadir)/$(PACKAGE)/form form_DATA = \ nodo.form \ struttura.form \ + struttura_indirizzo.form \ tipo_nodo.form \ tipo_recapito.form \ ufficio.form diff --git a/data/organigramma/form/struttura_indirizzo.form b/data/organigramma/form/struttura_indirizzo.form new file mode 100644 index 0000000..21f60ce --- /dev/null +++ b/data/organigramma/form/struttura_indirizzo.form @@ -0,0 +1,44 @@ + + + + struttura_indirizzi
+ + + + t + t + + + + + + + + + + + f + f + + + + + + entry12 + + SELECT nome FROM vie WHERE id = ##label46::gint + + + + + + + + + + + + + + +
diff --git a/data/organigramma/gui/organigramma.gui b/data/organigramma/gui/organigramma.gui index f13b0ca..b8fef5e 100644 --- a/data/organigramma/gui/organigramma.gui +++ b/data/organigramma/gui/organigramma.gui @@ -476,31 +476,37 @@ - + - + - + - + + + + + + + - + - + - + @@ -1906,7 +1912,7 @@ True - 5 + 6 2 5 5 @@ -2052,6 +2058,121 @@ GTK_FILL + + + True + 0 + + + True + 12 + + + True + 5 + + + True + True + automatic + automatic + etched-in + + + True + True + lstore_struttura_indirizzi + False + 0 + + + Indirizzo + + + + 1 + + + + + + + + + 0 + + + + + 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 + 1 + + + + + + + + + True + <b>Indirizzi</b> + True + + + + + 2 + 5 + 6 + + 0 @@ -2543,4 +2664,209 @@ + + Indirizzo della struttura - Gestione organigramma + True + center-on-parent + True + + + True + 5 + vertical + 5 + + + True + 4 + 2 + 5 + 5 + + + True + 0 + 0 + Note + + + 2 + 3 + GTK_FILL + GTK_FILL + + + + + True + True + automatic + automatic + etched-in + + + True + True + + + + + 1 + 2 + 2 + 3 + + + + + True + 0 + Via + + + GTK_FILL + GTK_FILL + + + + + True + 5 + + + True + True + False + + + + 0 + + + + + ... + True + True + True + + + False + 1 + + + + + lbl_id_vie + + + False + 2 + + + + + 1 + 2 + GTK_FILL + + + + + 0 + lbl_id + + + 3 + 4 + GTK_FILL + GTK_FILL + + + + + lbl_id_strutture + + + 1 + 2 + 3 + 4 + + + + + True + 0 + Civico + + + 1 + 2 + GTK_FILL + GTK_FILL + + + + + True + True + 10 + + + + 1 + 2 + 1 + 2 + GTK_FILL + + + + + 0 + + + + + True + 5 + end + + + gtk-cancel + True + True + True + True + + + False + False + 0 + + + + + gtk-save + True + True + True + True + + + False + False + 1 + + + + + False + 1 + + + + + diff --git a/docs/organigramma.sql b/docs/organigramma.sql index 3f01493..38dbcee 100644 --- a/docs/organigramma.sql +++ b/docs/organigramma.sql @@ -2,7 +2,7 @@ -- PostgreSQL database dump -- --- Started on 2010-08-16 10:18:29 +-- Started on 2010-08-16 10:29:29 SET statement_timeout = 0; SET client_encoding = 'UTF8'; @@ -12,7 +12,7 @@ SET client_min_messages = warning; SET escape_string_warning = off; -- --- TOC entry 1817 (class 1262 OID 59278) +-- TOC entry 1826 (class 1262 OID 59278) -- Name: organigramma; Type: DATABASE; Schema: -; Owner: - -- @@ -29,7 +29,7 @@ SET client_min_messages = warning; SET escape_string_warning = off; -- --- TOC entry 317 (class 2612 OID 16386) +-- TOC entry 320 (class 2612 OID 16386) -- Name: plpgsql; Type: PROCEDURAL LANGUAGE; Schema: -; Owner: - -- @@ -43,8 +43,8 @@ SET default_tablespace = ''; SET default_with_oids = false; -- --- TOC entry 1504 (class 1259 OID 59279) --- Dependencies: 1787 1788 1789 3 +-- TOC entry 1507 (class 1259 OID 59279) +-- Dependencies: 1791 1792 1793 3 -- Name: nodi; Type: TABLE; Schema: public; Owner: -; Tablespace: -- @@ -59,8 +59,24 @@ CREATE TABLE nodi ( -- --- TOC entry 1508 (class 1259 OID 59327) --- Dependencies: 1797 1798 1799 1800 1801 3 +-- TOC entry 1513 (class 1259 OID 59346) +-- Dependencies: 1807 1808 1809 3 +-- Name: struttura_indirizzi; Type: TABLE; Schema: public; Owner: -; Tablespace: +-- + +CREATE TABLE struttura_indirizzi ( + id integer NOT NULL, + id_strutture integer, + id_vie integer, + civico character varying(10) DEFAULT ''::character varying, + note text DEFAULT ''::text, + status character varying(1) DEFAULT ''::character varying +); + + +-- +-- TOC entry 1511 (class 1259 OID 59327) +-- Dependencies: 1801 1802 1803 1804 1805 3 -- Name: strutture; Type: TABLE; Schema: public; Owner: -; Tablespace: -- @@ -75,8 +91,8 @@ CREATE TABLE strutture ( -- --- TOC entry 1505 (class 1259 OID 59290) --- Dependencies: 1790 1791 3 +-- TOC entry 1508 (class 1259 OID 59290) +-- Dependencies: 1794 1795 3 -- Name: tipi_nodo; Type: TABLE; Schema: public; Owner: -; Tablespace: -- @@ -88,8 +104,8 @@ CREATE TABLE tipi_nodo ( -- --- TOC entry 1506 (class 1259 OID 59297) --- Dependencies: 1792 1793 3 +-- TOC entry 1509 (class 1259 OID 59297) +-- Dependencies: 1796 1797 3 -- Name: tipi_recapito; Type: TABLE; Schema: public; Owner: -; Tablespace: -- @@ -101,8 +117,8 @@ CREATE TABLE tipi_recapito ( -- --- TOC entry 1507 (class 1259 OID 59311) --- Dependencies: 1794 1795 1796 3 +-- TOC entry 1510 (class 1259 OID 59311) +-- Dependencies: 1798 1799 1800 3 -- Name: uffici; Type: TABLE; Schema: public; Owner: -; Tablespace: -- @@ -116,8 +132,8 @@ CREATE TABLE uffici ( -- --- TOC entry 1509 (class 1259 OID 59340) --- Dependencies: 1802 3 +-- TOC entry 1512 (class 1259 OID 59340) +-- Dependencies: 1806 3 -- Name: vie; Type: TABLE; Schema: public; Owner: -; Tablespace: -- @@ -128,8 +144,8 @@ CREATE TABLE vie ( -- --- TOC entry 1804 (class 2606 OID 59289) --- Dependencies: 1504 1504 +-- TOC entry 1811 (class 2606 OID 59289) +-- Dependencies: 1507 1507 -- Name: nodi_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: -- @@ -138,8 +154,18 @@ ALTER TABLE ONLY nodi -- --- TOC entry 1812 (class 2606 OID 59339) --- Dependencies: 1508 1508 +-- TOC entry 1823 (class 2606 OID 59356) +-- Dependencies: 1513 1513 +-- Name: struttura_indirizzi_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: +-- + +ALTER TABLE ONLY struttura_indirizzi + ADD CONSTRAINT struttura_indirizzi_pkey PRIMARY KEY (id); + + +-- +-- TOC entry 1819 (class 2606 OID 59339) +-- Dependencies: 1511 1511 -- Name: strutture_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: -- @@ -148,8 +174,8 @@ ALTER TABLE ONLY strutture -- --- TOC entry 1806 (class 2606 OID 59296) --- Dependencies: 1505 1505 +-- TOC entry 1813 (class 2606 OID 59296) +-- Dependencies: 1508 1508 -- Name: tipi_nodo_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: -- @@ -158,8 +184,8 @@ ALTER TABLE ONLY tipi_nodo -- --- TOC entry 1808 (class 2606 OID 59303) --- Dependencies: 1506 1506 +-- TOC entry 1815 (class 2606 OID 59303) +-- Dependencies: 1509 1509 -- Name: tipi_recapito_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: -- @@ -168,8 +194,8 @@ ALTER TABLE ONLY tipi_recapito -- --- TOC entry 1810 (class 2606 OID 59321) --- Dependencies: 1507 1507 +-- TOC entry 1817 (class 2606 OID 59321) +-- Dependencies: 1510 1510 -- Name: uffici_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: -- @@ -178,8 +204,8 @@ ALTER TABLE ONLY uffici -- --- TOC entry 1814 (class 2606 OID 59345) --- Dependencies: 1509 1509 +-- TOC entry 1821 (class 2606 OID 59345) +-- Dependencies: 1512 1512 -- Name: vie_pkey; Type: CONSTRAINT; Schema: public; Owner: -; Tablespace: -- @@ -188,7 +214,7 @@ ALTER TABLE ONLY vie -- --- TOC entry 1819 (class 0 OID 0) +-- TOC entry 1828 (class 0 OID 0) -- Dependencies: 3 -- Name: public; Type: ACL; Schema: -; Owner: - -- @@ -199,7 +225,7 @@ GRANT ALL ON SCHEMA public TO postgres; GRANT ALL ON SCHEMA public TO PUBLIC; --- Completed on 2010-08-16 10:18:29 +-- Completed on 2010-08-16 10:29:30 -- -- PostgreSQL database dump complete diff --git a/src/Makefile.am b/src/Makefile.am index b9f55d7..c70ae5d 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -19,6 +19,8 @@ organigramma_SOURCES = \ nodo.h \ struttura.c \ struttura.h \ + strutturaindirizzo.c \ + strutturaindirizzo.h \ strutture.c \ strutture.h \ tipinodo.c \ diff --git a/src/struttura.c b/src/struttura.c index f0f7bf5..eb7cfcf 100644 --- a/src/struttura.c +++ b/src/struttura.c @@ -20,6 +20,7 @@ #include #include "struttura.h" +#include "strutturaindirizzo.h" static void struttura_class_init (StrutturaClass *klass); static void struttura_init (Struttura *struttura); @@ -27,6 +28,10 @@ static void struttura_init (Struttura *struttura); static void struttura_carica (Struttura *struttura); static void struttura_salva (Struttura *struttura); +static void struttura_carica_indirizzi (Struttura *struttura); + +static void struttura_indirizzo_modifica (Struttura *struttura); + static gboolean struttura_conferma_chiusura (Struttura *struttura); static void struttura_set_property (GObject *object, @@ -38,10 +43,23 @@ static void struttura_get_property (GObject *object, GValue *value, GParamSpec *pspec); +static void struttura_on_indirizzo_aggiornato (gpointer instance, gpointer user_data); + static gboolean struttura_on_w_struttura_delete_event (GtkWidget *widget, GdkEvent *event, gpointer user_data); +static void struttura_on_btn_indirizzo_nuovo_clicked (GtkButton *button, + gpointer user_data); +static void struttura_on_btn_indirizzo_modifica_clicked (GtkButton *button, + gpointer user_data); +static void struttura_on_btn_indirizzo_elimina_clicked (GtkButton *button, + gpointer user_data); +static void struttura_on_trv_indirizzi_row_activated (GtkTreeView *tree_view, + GtkTreePath *tree_path, + GtkTreeViewColumn *column, + gpointer user_data); + static void struttura_on_btn_annulla_clicked (GtkButton *button, gpointer user_data); static void struttura_on_btn_salva_clicked (GtkButton *button, @@ -51,7 +69,14 @@ static void struttura_on_btn_salva_clicked (GtkButton *button, enum { - LBL_ID + LBL_ID, + LSTORE_INDIRIZZI +}; + +enum +{ + INDIRIZZI_COL_ID, + INDIRIZZI_COL_INDIRIZZO }; typedef struct _StrutturaPrivate StrutturaPrivate; @@ -65,6 +90,8 @@ struct _StrutturaPrivate GObject **objects; + GtkTreeSelection *sel_indirizzi; + gint id; }; @@ -122,7 +149,8 @@ Struttura error = NULL; gtk_builder_add_objects_from_file (priv->commons->gtkbuilder, priv->commons->guifile, - g_strsplit ("w_struttura", "|", -1), + g_strsplit (g_strconcat ("lstore_struttura_indirizzi", + "|w_struttura", NULL), "|", -1), &error); if (error != NULL) { @@ -138,11 +166,23 @@ Struttura priv->objects = gtk_form_get_objects_by_name (priv->form, "label31", + "lstore_struttura_indirizzi", NULL); g_signal_connect (priv->w, "delete-event", G_CALLBACK (struttura_on_w_struttura_delete_event), (gpointer *)a); + priv->sel_indirizzi = gtk_tree_view_get_selection (GTK_TREE_VIEW (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview9"))); + + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button47")), + "clicked", G_CALLBACK (struttura_on_btn_indirizzo_nuovo_clicked), (gpointer *)a); + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button50")), + "clicked", G_CALLBACK (struttura_on_btn_indirizzo_modifica_clicked), (gpointer *)a); + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button51")), + "clicked", G_CALLBACK (struttura_on_btn_indirizzo_elimina_clicked), (gpointer *)a); + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview9")), + "row-activated", G_CALLBACK (struttura_on_trv_indirizzi_row_activated), (gpointer *)a); + g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button39"), "clicked", G_CALLBACK (struttura_on_btn_annulla_clicked), (gpointer *)a); g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button40"), @@ -184,7 +224,10 @@ struttura_carica (Struttura *struttura) { StrutturaPrivate *priv = STRUTTURA_GET_PRIVATE (struttura); - gtk_form_fill_from_table (priv->form); + if (gtk_form_fill_from_table (priv->form)) + { + struttura_carica_indirizzi (struttura); + } } static void @@ -251,6 +294,83 @@ struttura_salva (Struttura *struttura) } } +static void +struttura_carica_indirizzi (Struttura *struttura) +{ + gchar *sql; + GdaDataModel *dm; + guint row; + guint rows; + + StrutturaPrivate *priv = STRUTTURA_GET_PRIVATE (struttura); + + gtk_list_store_clear (GTK_LIST_STORE (priv->objects[LSTORE_INDIRIZZI])); + + sql = g_strdup_printf ("SELECT si.id, v.nome, si.civico" + " FROM struttura_indirizzi si INNER JOIN vie v ON" + " si.id_vie = v.id" + " WHERE si.id_strutture = %d" + " AND status <> 'E'", + priv->id); + dm = gdaex_query (priv->commons->gdaex, 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_INDIRIZZI]), &iter); + gtk_list_store_set (GTK_LIST_STORE (priv->objects[LSTORE_INDIRIZZI]), &iter, + INDIRIZZI_COL_ID, gdaex_data_model_get_value_integer_at (dm, row, 0), + INDIRIZZI_COL_INDIRIZZO, g_strconcat (gdaex_data_model_get_value_stringify_at (dm, row, 1), + (g_strcmp0 (gdaex_data_model_get_value_stringify_at (dm, row, 2), "") != 0 ? g_strdup_printf (", %s", gdaex_data_model_get_value_stringify_at (dm, row, 2)) : ""), NULL), + -1); + } + + g_object_unref (dm); + } + g_free (sql); +} + +static void +struttura_indirizzo_modifica (Struttura *struttura) +{ + GtkTreeIter iter; + GtkWidget *dialog; + + StrutturaPrivate *priv = STRUTTURA_GET_PRIVATE (struttura); + + if (gtk_tree_selection_get_selected (priv->sel_indirizzi, NULL, &iter)) + { + guint id; + GtkWidget *w; + + gtk_tree_model_get (GTK_TREE_MODEL (priv->objects[LSTORE_INDIRIZZI]), &iter, + INDIRIZZI_COL_ID, &id, + -1); + + StrutturaIndirizzo *a = struttura_indirizzo_new (priv->commons, id, 0); + + g_signal_connect (G_OBJECT (a), "aggiornato", + G_CALLBACK (struttura_on_indirizzo_aggiornato), (gpointer)struttura); + + w = struttura_indirizzo_get_widget (a); + gtk_window_set_transient_for (GTK_WINDOW (w), GTK_WINDOW (priv->w)); + gtk_widget_show (w); + } + else + { + dialog = gtk_message_dialog_new (GTK_WINDOW (priv->w), + GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_MESSAGE_WARNING, + GTK_BUTTONS_OK, + "Occorre prima selezionare un indirizzo"); + gtk_dialog_run (GTK_DIALOG (dialog)); + gtk_widget_destroy (dialog); + } +} + static void struttura_set_property (GObject *object, guint property_id, const GValue *value, GParamSpec *pspec) { @@ -309,6 +429,15 @@ struttura_conferma_chiusura (Struttura *struttura) } /* CALLBACK */ +static void +struttura_on_indirizzo_aggiornato (gpointer instance, gpointer user_data) +{ + Struttura *struttura = (Struttura *)user_data; + StrutturaClass *klass = STRUTTURA_GET_CLASS (struttura); + + struttura_carica_indirizzi (struttura); +} + static gboolean struttura_on_w_struttura_delete_event (GtkWidget *widget, GdkEvent *event, @@ -317,6 +446,93 @@ struttura_on_w_struttura_delete_event (GtkWidget *widget, return !struttura_conferma_chiusura ((Struttura *)user_data); } +static void +struttura_on_btn_indirizzo_nuovo_clicked (GtkButton *button, + gpointer user_data) +{ + GtkWidget *w; + + Struttura *struttura = (Struttura *)user_data; + + StrutturaPrivate *priv = STRUTTURA_GET_PRIVATE (struttura); + + StrutturaIndirizzo *a = struttura_indirizzo_new (priv->commons, 0, priv->id); + + g_signal_connect (G_OBJECT (a), "aggiornato", + G_CALLBACK (struttura_on_indirizzo_aggiornato), (gpointer)struttura); + + w = struttura_indirizzo_get_widget (a); + gtk_window_set_transient_for (GTK_WINDOW (w), GTK_WINDOW (priv->w)); + gtk_widget_show (w); +} + +static void +struttura_on_btn_indirizzo_modifica_clicked (GtkButton *button, + gpointer user_data) +{ + struttura_indirizzo_modifica ((Struttura *)user_data); +} + +static void +struttura_on_btn_indirizzo_elimina_clicked (GtkButton *button, + gpointer user_data) +{ + GtkTreeIter iter; + GtkWidget *dialog; + guint risp; + + Struttura *struttura = (Struttura *)user_data; + + StrutturaClass *klass = STRUTTURA_GET_CLASS (struttura); + StrutturaPrivate *priv = STRUTTURA_GET_PRIVATE (struttura); + + if (gtk_tree_selection_get_selected (priv->sel_indirizzi, NULL, &iter)) + { + dialog = gtk_message_dialog_new (GTK_WINDOW (priv->w), + GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_MESSAGE_QUESTION, + GTK_BUTTONS_YES_NO, + "Sicuro di voler eliminare l'indirizzo selezionato?"); + risp = gtk_dialog_run (GTK_DIALOG (dialog)); + if (risp == GTK_RESPONSE_YES) + { + guint id; + + gtk_tree_model_get (GTK_TREE_MODEL (priv->objects[LSTORE_INDIRIZZI]), &iter, + INDIRIZZI_COL_ID, &id, + -1); + + gdaex_execute (priv->commons->gdaex, + g_strdup_printf ("UPDATE struttura_indirizzi" + " SET status = 'E'" + " WHERE id = %d", + id)); + + struttura_carica_indirizzi (struttura); + } + gtk_widget_destroy (dialog); + } + else + { + dialog = gtk_message_dialog_new (GTK_WINDOW (priv->w), + GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_MESSAGE_WARNING, + GTK_BUTTONS_OK, + "Occorre prima selezionare un indirizzo"); + gtk_dialog_run (GTK_DIALOG (dialog)); + gtk_widget_destroy (dialog); + } +} + +static void +struttura_on_trv_indirizzi_row_activated (GtkTreeView *tree_view, + GtkTreePath *tree_path, + GtkTreeViewColumn *column, + gpointer user_data) +{ + struttura_indirizzo_modifica ((Struttura *)user_data); +} + static void struttura_on_btn_annulla_clicked (GtkButton *button, gpointer user_data) diff --git a/src/strutturaindirizzo.c b/src/strutturaindirizzo.c new file mode 100644 index 0000000..649aba6 --- /dev/null +++ b/src/strutturaindirizzo.c @@ -0,0 +1,386 @@ +/* + * Copyright (C) 2009 Andrea Zagli + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + * + */ + +#ifdef HAVE_CONFIG_H + #include +#endif + +#include + +#include "strutturaindirizzo.h" + +#include "vie.h" + +static void struttura_indirizzo_class_init (StrutturaIndirizzoClass *klass); +static void struttura_indirizzo_init (StrutturaIndirizzo *struttura_indirizzo); + +static void struttura_indirizzo_carica (StrutturaIndirizzo *struttura_indirizzo); +static void struttura_indirizzo_salva (StrutturaIndirizzo *struttura_indirizzo); + +static void struttura_indirizzo_carica_indirizzo (StrutturaIndirizzo *indirizzo); + +static gboolean struttura_indirizzo_conferma_chiusura (StrutturaIndirizzo *struttura_indirizzo); + +static void indirizzo_on_vie_selezionato (gpointer instance, + guint id, gpointer user_data); + +static void struttura_indirizzo_set_property (GObject *object, + guint property_id, + const GValue *value, + GParamSpec *pspec); +static void struttura_indirizzo_get_property (GObject *object, + guint property_id, + GValue *value, + GParamSpec *pspec); + +static gboolean struttura_indirizzo_on_w_struttura_indirizzo_delete_event (GtkWidget *widget, + GdkEvent *event, + gpointer user_data); + +static void struttura_indirizzo_on_btn_ricerca_via_clicked (GtkButton *button, + gpointer user_data); +static void struttura_indirizzo_on_btn_annulla_clicked (GtkButton *button, + gpointer user_data); +static void struttura_indirizzo_on_btn_salva_clicked (GtkButton *button, + gpointer user_data); + + +#define STRUTTURA_INDIRIZZO_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), TYPE_STRUTTURA_INDIRIZZO, StrutturaIndirizzoPrivate)) + +enum +{ + LBL_ID, + LBL_ID_STRUTTURE, + LBL_ID_VIE +}; + +typedef struct _StrutturaIndirizzoPrivate StrutturaIndirizzoPrivate; +struct _StrutturaIndirizzoPrivate + { + Commons *commons; + + GtkForm *form; + + GtkWidget *w; + + GObject **objects; + + guint id; + }; + +G_DEFINE_TYPE (StrutturaIndirizzo, struttura_indirizzo, G_TYPE_OBJECT) + +static void +struttura_indirizzo_class_init (StrutturaIndirizzoClass *klass) +{ + GObjectClass *object_class = G_OBJECT_CLASS (klass); + + g_type_class_add_private (object_class, sizeof (StrutturaIndirizzoPrivate)); + + object_class->set_property = struttura_indirizzo_set_property; + object_class->get_property = struttura_indirizzo_get_property; + + /** + * StrutturaIndirizzo::aggiornato: + * @struttura_indirizzo: + * + */ + klass->aggiornato_signal_id = g_signal_new ("aggiornato", + G_TYPE_FROM_CLASS (object_class), + G_SIGNAL_RUN_LAST, + 0, + NULL, + NULL, + g_cclosure_marshal_VOID__VOID, + G_TYPE_NONE, + 0); +} + +static void +struttura_indirizzo_init (StrutturaIndirizzo *struttura_indirizzo) +{ + StrutturaIndirizzoPrivate *priv = STRUTTURA_INDIRIZZO_GET_PRIVATE (struttura_indirizzo); +} + +/** + * struttura_indirizzo_new: + * @commons: + * @id: + * @id_strutture: + * + * Returns: the newly created #StrutturaIndirizzo object. + */ +StrutturaIndirizzo +*struttura_indirizzo_new (Commons *commons, guint id, guint id_strutture) +{ + GError *error; + + StrutturaIndirizzo *a = STRUTTURA_INDIRIZZO (g_object_new (struttura_indirizzo_get_type (), NULL)); + + StrutturaIndirizzoPrivate *priv = STRUTTURA_INDIRIZZO_GET_PRIVATE (a); + + priv->commons = commons; + + error = NULL; + + gtk_builder_add_objects_from_file (priv->commons->gtkbuilder, priv->commons->guifile, + g_strsplit ("w_struttura_indirizzo", "|", -1), + &error); + if (error != NULL) + { + g_fprintf (stderr, "Errore: %s\n", error->message); + return NULL; + } + + priv->form = gtk_form_new (); + g_object_set (G_OBJECT (priv->form), "gdaex", priv->commons->gdaex, NULL); + gtk_form_load_from_file (priv->form, g_build_filename (priv->commons->formdir, "struttura_indirizzo.form", NULL), priv->commons->gtkbuilder); + + priv->w = GTK_WIDGET (gtk_builder_get_object (priv->commons->gtkbuilder, "w_struttura_indirizzo")); + + priv->objects = gtk_form_get_objects_by_name (priv->form, + "label47", + "label48", + "label46", + NULL); + + g_signal_connect (priv->w, + "delete-event", G_CALLBACK (struttura_indirizzo_on_w_struttura_indirizzo_delete_event), (gpointer *)a); + + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button54")), + "clicked", G_CALLBACK (struttura_indirizzo_on_btn_ricerca_via_clicked), (gpointer *)a); + + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button55")), + "clicked", G_CALLBACK (struttura_indirizzo_on_btn_annulla_clicked), (gpointer *)a); + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button56")), + "clicked", G_CALLBACK (struttura_indirizzo_on_btn_salva_clicked), (gpointer *)a); + + priv->id = id; + if (priv->id == 0) + { + gtk_label_set_text (GTK_LABEL (priv->objects[LBL_ID]), ""); + gtk_label_set_text (GTK_LABEL (priv->objects[LBL_ID_STRUTTURE]), g_strdup_printf ("%d", id_strutture)); + + gtk_form_set_as_origin (priv->form); + } + else + { + gtk_label_set_text (GTK_LABEL (priv->objects[LBL_ID]), g_strdup_printf ("%d", priv->id)); + + struttura_indirizzo_carica (a); + } + + return a; +} + +/** + * struttura_indirizzo_get_widget: + * @struttura_indirizzo: + * + */ +GtkWidget +*struttura_indirizzo_get_widget (StrutturaIndirizzo *struttura_indirizzo) +{ + StrutturaIndirizzoPrivate *priv = STRUTTURA_INDIRIZZO_GET_PRIVATE (struttura_indirizzo); + + return priv->w; +} + +/* PRIVATE */ +static void +struttura_indirizzo_carica (StrutturaIndirizzo *struttura_indirizzo) +{ + gchar *sql; + GdaDataModel *dm; + + StrutturaIndirizzoPrivate *priv = STRUTTURA_INDIRIZZO_GET_PRIVATE (struttura_indirizzo); + + if (gtk_form_fill_from_table (priv->form)) + { + } +} + +static void +struttura_indirizzo_salva (StrutturaIndirizzo *struttura_indirizzo) +{ + gchar *sql; + GtkWidget *dialog; + + StrutturaIndirizzoClass *klass = STRUTTURA_INDIRIZZO_GET_CLASS (struttura_indirizzo); + + StrutturaIndirizzoPrivate *priv = STRUTTURA_INDIRIZZO_GET_PRIVATE (struttura_indirizzo); + + if (!gtk_form_check (priv->form, FALSE, NULL, TRUE, priv->w, TRUE)) + { + return; + } + + if (priv->id == 0) + { + sql = gtk_form_get_sql (priv->form, GTK_FORM_SQL_INSERT); + } + else + { + sql = gtk_form_get_sql (priv->form, GTK_FORM_SQL_UPDATE); + } + + if (gdaex_execute (priv->commons->gdaex, sql) == 1) + { + g_signal_emit (struttura_indirizzo, klass->aggiornato_signal_id, 0); + + if (priv->id == 0) + { + priv->id = strtol (gtk_label_get_text (GTK_LABEL (priv->objects[LBL_ID])), NULL, 10); + } + + gtk_form_set_as_origin (priv->form); + + dialog = gtk_message_dialog_new (GTK_WINDOW (priv->w), + GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_MESSAGE_INFO, + GTK_BUTTONS_OK, + "Salvataggio eseguito con successo."); + gtk_dialog_run (GTK_DIALOG (dialog)); + gtk_widget_destroy (dialog); + } + else + { + dialog = gtk_message_dialog_new (GTK_WINDOW (priv->w), + GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_MESSAGE_WARNING, + GTK_BUTTONS_OK, + "Errore durante il salvataggio"); + gtk_dialog_run (GTK_DIALOG (dialog)); + gtk_widget_destroy (dialog); + } +} + +static void +struttura_indirizzo_on_vie_selezionato (gpointer instance, guint id, gpointer user_data) +{ + StrutturaIndirizzo *ia = (StrutturaIndirizzo *)user_data; + + StrutturaIndirizzoPrivate *priv = STRUTTURA_INDIRIZZO_GET_PRIVATE (ia); + + gtk_form_widget_set_value_stringify (gtk_form_get_form_widget_from_name (priv->form, "label46"), g_strdup_printf ("%d", id)); +} + +static void +struttura_indirizzo_set_property (GObject *object, guint property_id, const GValue *value, GParamSpec *pspec) +{ + StrutturaIndirizzo *struttura_indirizzo = STRUTTURA_INDIRIZZO (object); + + StrutturaIndirizzoPrivate *priv = STRUTTURA_INDIRIZZO_GET_PRIVATE (struttura_indirizzo); + + switch (property_id) + { + default: + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); + break; + } +} + +static void +struttura_indirizzo_get_property (GObject *object, guint property_id, GValue *value, GParamSpec *pspec) +{ + StrutturaIndirizzo *struttura_indirizzo = STRUTTURA_INDIRIZZO (object); + + StrutturaIndirizzoPrivate *priv = STRUTTURA_INDIRIZZO_GET_PRIVATE (struttura_indirizzo); + + switch (property_id) + { + default: + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); + break; + } +} + +static gboolean +struttura_indirizzo_conferma_chiusura (StrutturaIndirizzo *struttura_indirizzo) +{ + GtkWidget *dialog; + + gboolean ret; + + StrutturaIndirizzoPrivate *priv = STRUTTURA_INDIRIZZO_GET_PRIVATE (struttura_indirizzo); + + ret = TRUE; + + if (gtk_form_is_changed (priv->form)) + { + dialog = gtk_message_dialog_new (GTK_WINDOW (priv->w), + GTK_DIALOG_DESTROY_WITH_PARENT, + GTK_MESSAGE_QUESTION, + GTK_BUTTONS_YES_NO, + "Sicuro di voler chiudere senza salvare?"); + if (gtk_dialog_run (GTK_DIALOG (dialog)) == GTK_RESPONSE_NO) + { + ret = FALSE; + } + gtk_widget_destroy (dialog); + } + + return ret; +} + +/* CALLBACK */ +static gboolean +struttura_indirizzo_on_w_struttura_indirizzo_delete_event (GtkWidget *widget, + GdkEvent *event, + gpointer user_data) +{ + return !struttura_indirizzo_conferma_chiusura ((StrutturaIndirizzo *)user_data); +} + +static void +struttura_indirizzo_on_btn_ricerca_via_clicked (GtkButton *button, + gpointer user_data) +{ + GtkWidget *w; + + StrutturaIndirizzo *ia = (StrutturaIndirizzo *)user_data; + StrutturaIndirizzoPrivate *priv = STRUTTURA_INDIRIZZO_GET_PRIVATE (ia); + + Vie *v = vie_new (priv->commons); + + g_signal_connect (G_OBJECT (v), "selezionato", + G_CALLBACK (struttura_indirizzo_on_vie_selezionato), (gpointer)ia); + + w = vie_get_widget (v); + gtk_window_set_transient_for (GTK_WINDOW (w), GTK_WINDOW (priv->w)); + gtk_widget_show (w); +} + +static void +struttura_indirizzo_on_btn_annulla_clicked (GtkButton *button, + gpointer user_data) +{ + StrutturaIndirizzo *struttura_indirizzo = (StrutturaIndirizzo *)user_data; + + StrutturaIndirizzoPrivate *priv = STRUTTURA_INDIRIZZO_GET_PRIVATE (struttura_indirizzo); + + if (struttura_indirizzo_conferma_chiusura (struttura_indirizzo)) gtk_widget_destroy (priv->w); +} + +static void +struttura_indirizzo_on_btn_salva_clicked (GtkButton *button, + gpointer user_data) +{ + struttura_indirizzo_salva ((StrutturaIndirizzo *)user_data); +} diff --git a/src/strutturaindirizzo.h b/src/strutturaindirizzo.h new file mode 100644 index 0000000..db75c1a --- /dev/null +++ b/src/strutturaindirizzo.h @@ -0,0 +1,65 @@ +/* + * Copyright (C) 2009 Andrea Zagli + * + * This library is free software; you can redistribute it and/or + * modify it under the terms of the GNU Lesser General Public + * License as published by the Free Software Foundation; either + * version 2.1 of the License, or (at your option) any later version. + * + * This library is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU + * Lesser General Public License for more details. + * + * You should have received a copy of the GNU Lesser General Public + * License along with this library; if not, write to the Free Software + * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA + * + */ + +#ifndef __STRUTTURA_INDIRIZZO_H__ +#define __STRUTTURA_INDIRIZZO_H__ + +#include +#include + +#include + +#include "commons.h" + +G_BEGIN_DECLS + + +#define TYPE_STRUTTURA_INDIRIZZO (struttura_indirizzo_get_type ()) +#define STRUTTURA_INDIRIZZO(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_STRUTTURA_INDIRIZZO, StrutturaIndirizzo)) +#define STRUTTURA_INDIRIZZO_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_STRUTTURA_INDIRIZZO, StrutturaIndirizzoClass)) +#define IS_STRUTTURA_INDIRIZZO(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_STRUTTURA_INDIRIZZO)) +#define IS_STRUTTURA_INDIRIZZO_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_STRUTTURA_INDIRIZZO)) +#define STRUTTURA_INDIRIZZO_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_STRUTTURA_INDIRIZZO, StrutturaIndirizzoClass)) + + +typedef struct _StrutturaIndirizzo StrutturaIndirizzo; +typedef struct _StrutturaIndirizzoClass StrutturaIndirizzoClass; + +struct _StrutturaIndirizzo + { + GObject parent; + }; + +struct _StrutturaIndirizzoClass + { + GObjectClass parent_class; + + guint aggiornato_signal_id; + }; + +GType struttura_indirizzo_get_type (void) G_GNUC_CONST; + +StrutturaIndirizzo *struttura_indirizzo_new (Commons *commons, guint id, guint id_strutture); + +GtkWidget *struttura_indirizzo_get_widget (StrutturaIndirizzo *struttura_indirizzo); + + +G_END_DECLS + +#endif /* __STRUTTURA_INDIRIZZO_H__ */ -- 2.49.0