From: Andrea Zagli Date: Tue, 19 Oct 2010 09:44:56 +0000 (+0200) Subject: Gestione stanze dell'ufficio. X-Git-Tag: 0.0.3~35 X-Git-Url: https://saetta.ns0.it/gitweb?a=commitdiff_plain;h=b5401f52e964d6bbe58b48e249780d378cfcf595;p=solipa%2Forganigramma Gestione stanze dell'ufficio. --- diff --git a/data/organigramma/form/Makefile.am b/data/organigramma/form/Makefile.am index 942fd34..72cf39c 100644 --- a/data/organigramma/form/Makefile.am +++ b/data/organigramma/form/Makefile.am @@ -21,6 +21,7 @@ form_DATA = \ ufficio.form \ ufficio_nodo.form \ ufficio_orario.form \ - ufficio_recapito.form + ufficio_recapito.form \ + ufficio_stanza.form EXTRA_DIST = $(form_DATA) diff --git a/data/organigramma/form/ufficio_stanza.form b/data/organigramma/form/ufficio_stanza.form new file mode 100644 index 0000000..3dd2736 --- /dev/null +++ b/data/organigramma/form/ufficio_stanza.form @@ -0,0 +1,37 @@ + + + + ufficio_stanze
+ + + + t + t + + + + + + + + + + + + + + + + + + + + + + + + + + + +
diff --git a/data/organigramma/gui/organigramma.gui b/data/organigramma/gui/organigramma.gui index d1ef4b3..cec3279 100644 --- a/data/organigramma/gui/organigramma.gui +++ b/data/organigramma/gui/organigramma.gui @@ -748,6 +748,18 @@ + + + + + + + + + + + + True center-on-parent @@ -1568,7 +1580,7 @@ True - 7 + 8 2 5 5 @@ -1579,8 +1591,8 @@ Nome - 3 - 4 + 4 + 5 GTK_FILL GTK_FILL @@ -1595,8 +1607,8 @@ 1 2 - 3 - 4 + 4 + 5 GTK_FILL @@ -1608,8 +1620,8 @@ Descrizione - 4 - 5 + 5 + 6 GTK_FILL GTK_FILL @@ -1631,8 +1643,8 @@ 1 2 - 4 - 5 + 5 + 6 @@ -1836,8 +1848,8 @@ 2 - 5 - 6 + 6 + 7 @@ -2075,8 +2087,145 @@ 2 - 6 - 7 + 7 + 8 + + + + + True + 0 + + + True + 12 + + + True + 5 + + + True + True + automatic + automatic + etched-in + + + True + True + lstore_ufficio_stanze + False + 0 + + + Piano + + + + 1 + + + + + + + Da stanza + + + + 2 + + + + + + + A stanza + + + + 3 + + + + + + + + + 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>Stanze</b> + True + + + + + 2 + 3 + 4 @@ -7974,4 +8123,207 @@ + + Stanze dell'ufficio - Gestione organigramma + True + center-on-parent + True + + + True + 5 + vertical + 5 + + + True + 5 + 2 + 5 + 5 + + + True + 0 + 0 + Note + + + 3 + 4 + GTK_FILL + GTK_FILL + + + + + True + True + automatic + automatic + etched-in + + + True + True + + + + + 1 + 2 + 3 + 4 + + + + + True + 0 + Da stanza + + + 1 + 2 + GTK_FILL + GTK_FILL + + + + + 0 + lbl_id + + + 4 + 5 + GTK_FILL + GTK_FILL + + + + + lbl_id_uffici + + + 1 + 2 + 4 + 5 + + + + + True + 0 + Piano + + + GTK_FILL + GTK_FILL + + + + + True + True + 10 + + + + 1 + 2 + GTK_FILL + + + + + True + True + 10 + + + + 1 + 2 + 1 + 2 + GTK_FILL + + + + + True + 0 + A stanza + + + 2 + 3 + GTK_FILL + GTK_FILL + + + + + True + True + 10 + + + + 1 + 2 + 2 + 3 + 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 6f1a76d..08ad05c 100644 --- a/docs/organigramma.sql +++ b/docs/organigramma.sql @@ -4,7 +4,7 @@ -- Dumped from database version 8.4.4 -- Dumped by pg_dump version 9.0.1 --- Started on 2010-10-19 10:39:54 +-- Started on 2010-10-19 11:13:24 SET statement_timeout = 0; SET client_encoding = 'UTF8'; @@ -14,7 +14,7 @@ SET client_min_messages = warning; SET escape_string_warning = off; -- --- TOC entry 360 (class 2612 OID 16386) +-- TOC entry 362 (class 2612 OID 16386) -- Name: plpgsql; Type: PROCEDURAL LANGUAGE; Schema: -; Owner: - -- @@ -26,8 +26,8 @@ SET search_path = public, pg_catalog; SET default_with_oids = false; -- --- TOC entry 1547 (class 1259 OID 59279) --- Dependencies: 1846 1847 1848 3 +-- TOC entry 1549 (class 1259 OID 59279) +-- Dependencies: 1849 1850 1851 3 -- Name: nodi; Type: TABLE; Schema: public; Owner: - -- @@ -42,8 +42,8 @@ CREATE TABLE nodi ( -- --- TOC entry 1568 (class 1259 OID 61344) --- Dependencies: 1918 1919 1920 1921 1922 1923 1924 1925 1926 3 +-- TOC entry 1570 (class 1259 OID 61344) +-- Dependencies: 1921 1922 1923 1924 1925 1926 1927 1928 1929 3 -- Name: persona_incarichi; Type: TABLE; Schema: public; Owner: - -- @@ -64,8 +64,8 @@ CREATE TABLE persona_incarichi ( -- --- TOC entry 1563 (class 1259 OID 61295) --- Dependencies: 1901 1902 1903 1904 3 +-- TOC entry 1565 (class 1259 OID 61295) +-- Dependencies: 1904 1905 1906 1907 3 -- Name: persona_nodi; Type: TABLE; Schema: public; Owner: - -- @@ -81,8 +81,8 @@ CREATE TABLE persona_nodi ( -- --- TOC entry 1564 (class 1259 OID 61307) --- Dependencies: 1905 1906 1907 1908 1909 1910 1911 3 +-- TOC entry 1566 (class 1259 OID 61307) +-- Dependencies: 1908 1909 1910 1911 1912 1913 1914 3 -- Name: persona_nodo_recapiti; Type: TABLE; Schema: public; Owner: - -- @@ -99,8 +99,8 @@ CREATE TABLE persona_nodo_recapiti ( -- --- TOC entry 1561 (class 1259 OID 61266) --- Dependencies: 1888 1889 1890 1891 1892 1893 3 +-- TOC entry 1563 (class 1259 OID 61266) +-- Dependencies: 1891 1892 1893 1894 1895 1896 3 -- Name: persona_recapiti; Type: TABLE; Schema: public; Owner: - -- @@ -116,8 +116,8 @@ CREATE TABLE persona_recapiti ( -- --- TOC entry 1560 (class 1259 OID 61243) --- Dependencies: 1886 1887 3 +-- TOC entry 1562 (class 1259 OID 61243) +-- Dependencies: 1889 1890 3 -- Name: persona_uffici; Type: TABLE; Schema: public; Owner: - -- @@ -133,8 +133,8 @@ CREATE TABLE persona_uffici ( -- --- TOC entry 1562 (class 1259 OID 61280) --- Dependencies: 1894 1895 1896 1897 1898 1899 1900 3 +-- TOC entry 1564 (class 1259 OID 61280) +-- Dependencies: 1897 1898 1899 1900 1901 1902 1903 3 -- Name: persona_ufficio_recapiti; Type: TABLE; Schema: public; Owner: - -- @@ -151,8 +151,8 @@ CREATE TABLE persona_ufficio_recapiti ( -- --- TOC entry 1558 (class 1259 OID 61227) --- Dependencies: 1875 1876 1877 1878 1879 1880 1881 1882 1883 3 +-- TOC entry 1560 (class 1259 OID 61227) +-- Dependencies: 1878 1879 1880 1881 1882 1883 1884 1885 1886 3 -- Name: persone; Type: TABLE; Schema: public; Owner: - -- @@ -172,8 +172,8 @@ CREATE TABLE persone ( -- --- TOC entry 1565 (class 1259 OID 61322) --- Dependencies: 1912 1913 3 +-- TOC entry 1567 (class 1259 OID 61322) +-- Dependencies: 1915 1916 3 -- Name: posizioni_economiche; Type: TABLE; Schema: public; Owner: - -- @@ -185,8 +185,8 @@ CREATE TABLE posizioni_economiche ( -- --- TOC entry 1567 (class 1259 OID 61336) --- Dependencies: 1916 1917 3 +-- TOC entry 1569 (class 1259 OID 61336) +-- Dependencies: 1919 1920 3 -- Name: profili_professionali; Type: TABLE; Schema: public; Owner: - -- @@ -198,8 +198,8 @@ CREATE TABLE profili_professionali ( -- --- TOC entry 1553 (class 1259 OID 59346) --- Dependencies: 1862 1863 1864 3 +-- TOC entry 1555 (class 1259 OID 59346) +-- Dependencies: 1865 1866 1867 3 -- Name: struttura_indirizzi; Type: TABLE; Schema: public; Owner: - -- @@ -214,8 +214,8 @@ CREATE TABLE struttura_indirizzi ( -- --- TOC entry 1551 (class 1259 OID 59327) --- Dependencies: 1856 1857 1858 1859 1860 3 +-- TOC entry 1553 (class 1259 OID 59327) +-- Dependencies: 1859 1860 1861 1862 1863 3 -- Name: strutture; Type: TABLE; Schema: public; Owner: - -- @@ -230,8 +230,8 @@ CREATE TABLE strutture ( -- --- TOC entry 1548 (class 1259 OID 59290) --- Dependencies: 1849 1850 3 +-- TOC entry 1550 (class 1259 OID 59290) +-- Dependencies: 1852 1853 3 -- Name: tipi_nodo; Type: TABLE; Schema: public; Owner: - -- @@ -243,8 +243,8 @@ CREATE TABLE tipi_nodo ( -- --- TOC entry 1566 (class 1259 OID 61329) --- Dependencies: 1914 1915 3 +-- TOC entry 1568 (class 1259 OID 61329) +-- Dependencies: 1917 1918 3 -- Name: tipi_prestazione; Type: TABLE; Schema: public; Owner: - -- @@ -256,8 +256,8 @@ CREATE TABLE tipi_prestazione ( -- --- TOC entry 1559 (class 1259 OID 61236) --- Dependencies: 1884 1885 3 +-- TOC entry 1561 (class 1259 OID 61236) +-- Dependencies: 1887 1888 3 -- Name: tipi_rapporto_lavoro; Type: TABLE; Schema: public; Owner: - -- @@ -269,8 +269,8 @@ CREATE TABLE tipi_rapporto_lavoro ( -- --- TOC entry 1549 (class 1259 OID 59297) --- Dependencies: 1851 1852 3 +-- TOC entry 1551 (class 1259 OID 59297) +-- Dependencies: 1854 1855 3 -- Name: tipi_recapito; Type: TABLE; Schema: public; Owner: - -- @@ -282,8 +282,8 @@ CREATE TABLE tipi_recapito ( -- --- TOC entry 1557 (class 1259 OID 61219) --- Dependencies: 1872 1873 1874 3 +-- TOC entry 1559 (class 1259 OID 61219) +-- Dependencies: 1875 1876 1877 3 -- Name: titoli; Type: TABLE; Schema: public; Owner: - -- @@ -296,8 +296,8 @@ CREATE TABLE titoli ( -- --- TOC entry 1550 (class 1259 OID 59311) --- Dependencies: 1853 1854 1855 3 +-- TOC entry 1552 (class 1259 OID 59311) +-- Dependencies: 1856 1857 1858 3 -- Name: uffici; Type: TABLE; Schema: public; Owner: - -- @@ -311,8 +311,8 @@ CREATE TABLE uffici ( -- --- TOC entry 1554 (class 1259 OID 59357) --- Dependencies: 1865 1866 3 +-- TOC entry 1556 (class 1259 OID 59357) +-- Dependencies: 1868 1869 3 -- Name: ufficio_nodi; Type: TABLE; Schema: public; Owner: - -- @@ -326,8 +326,8 @@ CREATE TABLE ufficio_nodi ( -- --- TOC entry 1555 (class 1259 OID 59399) --- Dependencies: 1867 1868 3 +-- TOC entry 1557 (class 1259 OID 59399) +-- Dependencies: 1870 1871 3 -- Name: ufficio_orari; Type: TABLE; Schema: public; Owner: - -- @@ -354,8 +354,8 @@ CREATE TABLE ufficio_orari ( -- --- TOC entry 1556 (class 1259 OID 59409) --- Dependencies: 1869 1870 1871 3 +-- TOC entry 1558 (class 1259 OID 59409) +-- Dependencies: 1872 1873 1874 3 -- Name: ufficio_recapiti; Type: TABLE; Schema: public; Owner: - -- @@ -371,8 +371,24 @@ CREATE TABLE ufficio_recapiti ( -- --- TOC entry 1552 (class 1259 OID 59340) --- Dependencies: 1861 3 +-- TOC entry 1571 (class 1259 OID 61407) +-- Dependencies: 1930 1931 1932 1933 1934 3 +-- Name: ufficio_stanze; Type: TABLE; Schema: public; Owner: - +-- + +CREATE TABLE ufficio_stanze ( + id integer NOT NULL, + id_uffici integer DEFAULT 0, + piano character varying(10) DEFAULT ''::character varying, + da_stanza character varying(10) DEFAULT ''::character varying, + a_stanza character varying(10) DEFAULT ''::character varying, + status character varying(1) DEFAULT ''::character varying +); + + +-- +-- TOC entry 1554 (class 1259 OID 59340) +-- Dependencies: 1864 3 -- Name: vie; Type: TABLE; Schema: public; Owner: - -- @@ -383,8 +399,8 @@ CREATE TABLE vie ( -- --- TOC entry 1928 (class 2606 OID 59289) --- Dependencies: 1547 1547 +-- TOC entry 1936 (class 2606 OID 59289) +-- Dependencies: 1549 1549 -- Name: nodi_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -393,8 +409,8 @@ ALTER TABLE ONLY nodi -- --- TOC entry 1970 (class 2606 OID 61360) --- Dependencies: 1568 1568 +-- TOC entry 1978 (class 2606 OID 61360) +-- Dependencies: 1570 1570 -- Name: persona_incarichi_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -403,8 +419,8 @@ ALTER TABLE ONLY persona_incarichi -- --- TOC entry 1960 (class 2606 OID 61305) --- Dependencies: 1563 1563 +-- TOC entry 1968 (class 2606 OID 61305) +-- Dependencies: 1565 1565 -- Name: persona_nodi_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -413,8 +429,8 @@ ALTER TABLE ONLY persona_nodi -- --- TOC entry 1962 (class 2606 OID 61321) --- Dependencies: 1564 1564 +-- TOC entry 1970 (class 2606 OID 61321) +-- Dependencies: 1566 1566 -- Name: persona_nodo_recapiti_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -423,8 +439,8 @@ ALTER TABLE ONLY persona_nodo_recapiti -- --- TOC entry 1956 (class 2606 OID 61279) --- Dependencies: 1561 1561 +-- TOC entry 1964 (class 2606 OID 61279) +-- Dependencies: 1563 1563 -- Name: persona_recapiti_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -433,8 +449,8 @@ ALTER TABLE ONLY persona_recapiti -- --- TOC entry 1954 (class 2606 OID 61252) --- Dependencies: 1560 1560 +-- TOC entry 1962 (class 2606 OID 61252) +-- Dependencies: 1562 1562 -- Name: persona_uffici_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -443,8 +459,8 @@ ALTER TABLE ONLY persona_uffici -- --- TOC entry 1958 (class 2606 OID 61294) --- Dependencies: 1562 1562 +-- TOC entry 1966 (class 2606 OID 61294) +-- Dependencies: 1564 1564 -- Name: persona_ufficio_recapiti_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -453,8 +469,8 @@ ALTER TABLE ONLY persona_ufficio_recapiti -- --- TOC entry 1950 (class 2606 OID 61235) --- Dependencies: 1558 1558 +-- TOC entry 1958 (class 2606 OID 61235) +-- Dependencies: 1560 1560 -- Name: persone_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -463,8 +479,8 @@ ALTER TABLE ONLY persone -- --- TOC entry 1964 (class 2606 OID 61328) --- Dependencies: 1565 1565 +-- TOC entry 1972 (class 2606 OID 61328) +-- Dependencies: 1567 1567 -- Name: posizioni_economiche_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -473,8 +489,8 @@ ALTER TABLE ONLY posizioni_economiche -- --- TOC entry 1968 (class 2606 OID 61342) --- Dependencies: 1567 1567 +-- TOC entry 1976 (class 2606 OID 61342) +-- Dependencies: 1569 1569 -- Name: profili_professionali_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -483,8 +499,8 @@ ALTER TABLE ONLY profili_professionali -- --- TOC entry 1940 (class 2606 OID 59356) --- Dependencies: 1553 1553 +-- TOC entry 1948 (class 2606 OID 59356) +-- Dependencies: 1555 1555 -- Name: struttura_indirizzi_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -493,8 +509,8 @@ ALTER TABLE ONLY struttura_indirizzi -- --- TOC entry 1936 (class 2606 OID 59339) --- Dependencies: 1551 1551 +-- TOC entry 1944 (class 2606 OID 59339) +-- Dependencies: 1553 1553 -- Name: strutture_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -503,8 +519,8 @@ ALTER TABLE ONLY strutture -- --- TOC entry 1930 (class 2606 OID 59296) --- Dependencies: 1548 1548 +-- TOC entry 1938 (class 2606 OID 59296) +-- Dependencies: 1550 1550 -- Name: tipi_nodo_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -513,8 +529,8 @@ ALTER TABLE ONLY tipi_nodo -- --- TOC entry 1966 (class 2606 OID 61335) --- Dependencies: 1566 1566 +-- TOC entry 1974 (class 2606 OID 61335) +-- Dependencies: 1568 1568 -- Name: tipi_prestazione_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -523,8 +539,8 @@ ALTER TABLE ONLY tipi_prestazione -- --- TOC entry 1952 (class 2606 OID 61242) --- Dependencies: 1559 1559 +-- TOC entry 1960 (class 2606 OID 61242) +-- Dependencies: 1561 1561 -- Name: tipi_rapporto_lavoro_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -533,8 +549,8 @@ ALTER TABLE ONLY tipi_rapporto_lavoro -- --- TOC entry 1932 (class 2606 OID 59303) --- Dependencies: 1549 1549 +-- TOC entry 1940 (class 2606 OID 59303) +-- Dependencies: 1551 1551 -- Name: tipi_recapito_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -543,8 +559,8 @@ ALTER TABLE ONLY tipi_recapito -- --- TOC entry 1948 (class 2606 OID 61226) --- Dependencies: 1557 1557 +-- TOC entry 1956 (class 2606 OID 61226) +-- Dependencies: 1559 1559 -- Name: titoli_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -553,8 +569,8 @@ ALTER TABLE ONLY titoli -- --- TOC entry 1934 (class 2606 OID 59321) --- Dependencies: 1550 1550 +-- TOC entry 1942 (class 2606 OID 59321) +-- Dependencies: 1552 1552 -- Name: uffici_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -563,8 +579,8 @@ ALTER TABLE ONLY uffici -- --- TOC entry 1942 (class 2606 OID 59366) --- Dependencies: 1554 1554 +-- TOC entry 1950 (class 2606 OID 59366) +-- Dependencies: 1556 1556 -- Name: ufficio_nodi_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -573,8 +589,8 @@ ALTER TABLE ONLY ufficio_nodi -- --- TOC entry 1944 (class 2606 OID 59408) --- Dependencies: 1555 1555 +-- TOC entry 1952 (class 2606 OID 59408) +-- Dependencies: 1557 1557 -- Name: ufficio_orari_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -583,8 +599,8 @@ ALTER TABLE ONLY ufficio_orari -- --- TOC entry 1946 (class 2606 OID 59419) --- Dependencies: 1556 1556 +-- TOC entry 1954 (class 2606 OID 59419) +-- Dependencies: 1558 1558 -- Name: ufficio_recapiti_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -593,8 +609,18 @@ ALTER TABLE ONLY ufficio_recapiti -- --- TOC entry 1938 (class 2606 OID 59345) --- Dependencies: 1552 1552 +-- TOC entry 1980 (class 2606 OID 61416) +-- Dependencies: 1571 1571 +-- Name: ufficio_stanze_pkey; Type: CONSTRAINT; Schema: public; Owner: - +-- + +ALTER TABLE ONLY ufficio_stanze + ADD CONSTRAINT ufficio_stanze_pkey PRIMARY KEY (id); + + +-- +-- TOC entry 1946 (class 2606 OID 59345) +-- Dependencies: 1554 1554 -- Name: vie_pkey; Type: CONSTRAINT; Schema: public; Owner: - -- @@ -602,7 +628,7 @@ ALTER TABLE ONLY vie ADD CONSTRAINT vie_pkey PRIMARY KEY (id); --- Completed on 2010-10-19 10:39:54 +-- Completed on 2010-10-19 11:13:25 -- -- PostgreSQL database dump complete diff --git a/src/Makefile.am b/src/Makefile.am index fbd890f..a362377 100644 --- a/src/Makefile.am +++ b/src/Makefile.am @@ -77,5 +77,7 @@ organigramma_SOURCES = \ ufficioorario.h \ ufficiorecapito.c \ ufficiorecapito.h \ + ufficiostanza.c \ + ufficiostanza.h \ vie.c \ vie.h \ No newline at end of file diff --git a/src/ufficio.c b/src/ufficio.c index c7108af..085a712 100644 --- a/src/ufficio.c +++ b/src/ufficio.c @@ -24,6 +24,7 @@ #include "ufficionodo.h" #include "ufficioorario.h" #include "ufficiorecapito.h" +#include "ufficiostanza.h" static void ufficio_class_init (UfficioClass *klass); static void ufficio_init (Ufficio *ufficio); @@ -32,10 +33,12 @@ static void ufficio_carica (Ufficio *ufficio); static void ufficio_salva (Ufficio *ufficio); static void ufficio_carica_nodi (Ufficio *ufficio); +static void ufficio_carica_stanze (Ufficio *ufficio); static void ufficio_carica_recapiti (Ufficio *ufficio); static void ufficio_carica_orari (Ufficio *ufficio); static void ufficio_nodo_modifica (Ufficio *ufficio); +static void ufficio_stanza_modifica (Ufficio *ufficio); static void ufficio_recapito_modifica (Ufficio *ufficio); static void ufficio_orario_modifica (Ufficio *ufficio); @@ -51,10 +54,11 @@ static void ufficio_get_property (GObject *object, GParamSpec *pspec); static void ufficio_on_nodo_aggiornato (gpointer instance, gpointer user_data); +static void ufficio_on_stanza_aggiornato (gpointer instance, gpointer user_data); static void ufficio_on_recapito_aggiornato (gpointer instance, gpointer user_data); static void ufficio_on_orario_aggiornato (gpointer instance, gpointer user_data); -static void ufficio_on_ufficio_selezionato (gpointer instance, guint id, gpointer user_data); +static void ufficio_on_struttura_selezionato (gpointer instance, guint id, gpointer user_data); static gboolean ufficio_on_w_ufficio_delete_event (GtkWidget *widget, GdkEvent *event, @@ -74,6 +78,17 @@ static void ufficio_on_trv_nodi_row_activated (GtkTreeView *tree_view, GtkTreeViewColumn *column, gpointer user_data); +static void ufficio_on_btn_stanza_nuovo_clicked (GtkButton *button, + gpointer user_data); +static void ufficio_on_btn_stanza_modifica_clicked (GtkButton *button, + gpointer user_data); +static void ufficio_on_btn_stanza_elimina_clicked (GtkButton *button, + gpointer user_data); +static void ufficio_on_trv_stanze_row_activated (GtkTreeView *tree_view, + GtkTreePath *tree_path, + GtkTreeViewColumn *column, + gpointer user_data); + static void ufficio_on_btn_recapito_nuovo_clicked (GtkButton *button, gpointer user_data); static void ufficio_on_btn_recapito_modifica_clicked (GtkButton *button, @@ -107,6 +122,7 @@ enum { LBL_ID, LSTORE_NODI, + LSTORE_STANZE, LSTORE_RECAPITI, LSTORE_ORARI }; @@ -118,6 +134,14 @@ enum NODI_COL_NOME }; +enum +{ + STANZE_COL_ID, + STANZE_COL_PIANO, + STANZE_COL_DA_STANZA, + STANZE_COL_A_STANZA +}; + enum { RECAPITI_COL_TIPO, @@ -144,6 +168,7 @@ struct _UfficioPrivate GObject **objects; GtkTreeSelection *sel_nodi; + GtkTreeSelection *sel_stanze; GtkTreeSelection *sel_recapiti; GtkTreeSelection *sel_orari; @@ -205,6 +230,7 @@ Ufficio 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), @@ -224,11 +250,13 @@ Ufficio priv->objects = gtk_form_get_objects_by_name (priv->form, "label23", "lstore_ufficio_nodi", + "lstore_ufficio_stanze", "lstore_ufficio_recapiti", "lstore_ufficio_orari", 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"))); @@ -247,6 +275,15 @@ Ufficio g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview7")), "row-activated", G_CALLBACK (ufficio_on_trv_nodi_row_activated), (gpointer *)a); + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button137")), + "clicked", G_CALLBACK (ufficio_on_btn_stanza_nuovo_clicked), (gpointer *)a); + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button140")), + "clicked", G_CALLBACK (ufficio_on_btn_stanza_modifica_clicked), (gpointer *)a); + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button141")), + "clicked", G_CALLBACK (ufficio_on_btn_stanza_elimina_clicked), (gpointer *)a); + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview23")), + "row-activated", G_CALLBACK (ufficio_on_trv_stanze_row_activated), (gpointer *)a); + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button37")), "clicked", G_CALLBACK (ufficio_on_btn_recapito_nuovo_clicked), (gpointer *)a); g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button38")), @@ -309,6 +346,7 @@ ufficio_carica (Ufficio *ufficio) if (gtk_form_fill_from_table (priv->form)) { ufficio_carica_nodi (ufficio); + ufficio_carica_stanze (ufficio); ufficio_carica_recapiti (ufficio); ufficio_carica_orari (ufficio); } @@ -417,6 +455,46 @@ ufficio_carica_nodi (Ufficio *ufficio) g_free (sql); } +static void +ufficio_carica_stanze (Ufficio *ufficio) +{ + gchar *sql; + GdaDataModel *dm; + guint row; + guint rows; + + UfficioPrivate *priv = UFFICIO_GET_PRIVATE (ufficio); + + gtk_list_store_clear (GTK_LIST_STORE (priv->objects[LSTORE_STANZE])); + + sql = g_strdup_printf ("SELECT us.id, us.piano, us.da_stanza, us.a_stanza" + " FROM ufficio_stanze AS us" + " WHERE us.id_uffici = %d" + " AND us.status <> 'E'" + " ORDER BY us.piano, us.da_stanza, us.a_stanza", + 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_STANZE]), &iter); + gtk_list_store_set (GTK_LIST_STORE (priv->objects[LSTORE_STANZE]), &iter, + STANZE_COL_ID, gdaex_data_model_get_field_value_integer_at (dm, row, "id"), + STANZE_COL_PIANO, gdaex_data_model_get_field_value_stringify_at (dm, row, "piano"), + STANZE_COL_DA_STANZA, gdaex_data_model_get_field_value_stringify_at (dm, row, "da_stanza"), + STANZE_COL_A_STANZA, gdaex_data_model_get_field_value_stringify_at (dm, row, "a_stanza"), + -1); + } + + g_object_unref (dm); + } + g_free (sql); +} + static void ufficio_carica_recapiti (Ufficio *ufficio) { @@ -524,7 +602,45 @@ ufficio_nodo_modifica (Ufficio *ufficio) GTK_DIALOG_DESTROY_WITH_PARENT, GTK_MESSAGE_WARNING, GTK_BUTTONS_OK, - "Occorre prima selezionare un nodo"); + "Occorre prima selezionare un nodo."); + gtk_dialog_run (GTK_DIALOG (dialog)); + gtk_widget_destroy (dialog); + } +} + +static void +ufficio_stanza_modifica (Ufficio *ufficio) +{ + GtkTreeIter iter; + GtkWidget *dialog; + + UfficioPrivate *priv = UFFICIO_GET_PRIVATE (ufficio); + + if (gtk_tree_selection_get_selected (priv->sel_stanze, NULL, &iter)) + { + guint id; + GtkWidget *w; + + gtk_tree_model_get (GTK_TREE_MODEL (priv->objects[LSTORE_STANZE]), &iter, + STANZE_COL_ID, &id, + -1); + + UfficioStanza *a = ufficio_stanza_new (priv->commons, id, 0); + + g_signal_connect (G_OBJECT (a), "aggiornato", + G_CALLBACK (ufficio_on_stanza_aggiornato), (gpointer)ufficio); + + w = ufficio_stanza_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 una stanza."); gtk_dialog_run (GTK_DIALOG (dialog)); gtk_widget_destroy (dialog); } @@ -665,7 +781,7 @@ ufficio_conferma_chiusura (Ufficio *ufficio) /* CALLBACK */ static void -ufficio_on_ufficio_selezionato (gpointer instance, guint id, gpointer user_data) +ufficio_on_struttura_selezionato (gpointer instance, guint id, gpointer user_data) { Ufficio *f = (Ufficio *)user_data; UfficioPrivate *priv = UFFICIO_GET_PRIVATE (f); @@ -682,6 +798,15 @@ ufficio_on_nodo_aggiornato (gpointer instance, gpointer user_data) ufficio_carica_nodi (ufficio); } +static void +ufficio_on_stanza_aggiornato (gpointer instance, gpointer user_data) +{ + Ufficio *ufficio = (Ufficio *)user_data; + UfficioClass *klass = UFFICIO_GET_CLASS (ufficio); + + ufficio_carica_stanze (ufficio); +} + static void ufficio_on_recapito_aggiornato (gpointer instance, gpointer user_data) { @@ -721,7 +846,7 @@ ufficio_on_btn_ufficio_clicked (GtkButton *button, Strutture *c = strutture_new (priv->commons, TRUE); g_signal_connect (G_OBJECT (c), "selezionato", - G_CALLBACK (ufficio_on_ufficio_selezionato), user_data); + G_CALLBACK (ufficio_on_struttura_selezionato), user_data); w = strutture_get_widget (c); gtk_window_set_transient_for (GTK_WINDOW (w), GTK_WINDOW (priv->w)); @@ -815,6 +940,93 @@ ufficio_on_trv_nodi_row_activated (GtkTreeView *tree_view, ufficio_nodo_modifica ((Ufficio *)user_data); } +static void +ufficio_on_btn_stanza_nuovo_clicked (GtkButton *button, + gpointer user_data) +{ + GtkWidget *w; + + Ufficio *ufficio = (Ufficio *)user_data; + + UfficioPrivate *priv = UFFICIO_GET_PRIVATE (ufficio); + + UfficioStanza *a = ufficio_stanza_new (priv->commons, 0, priv->id); + + g_signal_connect (G_OBJECT (a), "aggiornato", + G_CALLBACK (ufficio_on_stanza_aggiornato), (gpointer)ufficio); + + w = ufficio_stanza_get_widget (a); + gtk_window_set_transient_for (GTK_WINDOW (w), GTK_WINDOW (priv->w)); + gtk_widget_show (w); +} + +static void +ufficio_on_btn_stanza_modifica_clicked (GtkButton *button, + gpointer user_data) +{ + ufficio_stanza_modifica ((Ufficio *)user_data); +} + +static void +ufficio_on_btn_stanza_elimina_clicked (GtkButton *button, + gpointer user_data) +{ + GtkTreeIter iter; + GtkWidget *dialog; + guint risp; + + Ufficio *ufficio = (Ufficio *)user_data; + + UfficioClass *klass = UFFICIO_GET_CLASS (ufficio); + UfficioPrivate *priv = UFFICIO_GET_PRIVATE (ufficio); + + if (gtk_tree_selection_get_selected (priv->sel_stanze, 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 la stanza selezionata?"); + risp = gtk_dialog_run (GTK_DIALOG (dialog)); + if (risp == GTK_RESPONSE_YES) + { + guint id; + + gtk_tree_model_get (GTK_TREE_MODEL (priv->objects[LSTORE_STANZE]), &iter, + STANZE_COL_ID, &id, + -1); + + gdaex_execute (priv->commons->gdaex, + g_strdup_printf ("UPDATE ufficio_stanze" + " SET status = 'E'" + " WHERE id = %d", + id)); + + ufficio_carica_stanze (ufficio); + } + 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 una stanza."); + gtk_dialog_run (GTK_DIALOG (dialog)); + gtk_widget_destroy (dialog); + } +} + +static void +ufficio_on_trv_stanze_row_activated (GtkTreeView *tree_view, + GtkTreePath *tree_path, + GtkTreeViewColumn *column, + gpointer user_data) +{ + ufficio_stanza_modifica ((Ufficio *)user_data); +} + static void ufficio_on_btn_recapito_nuovo_clicked (GtkButton *button, gpointer user_data) @@ -887,7 +1099,7 @@ ufficio_on_btn_recapito_elimina_clicked (GtkButton *button, GTK_DIALOG_DESTROY_WITH_PARENT, GTK_MESSAGE_WARNING, GTK_BUTTONS_OK, - "Occorre prima selezionare un recapito"); + "Occorre prima selezionare un recapito."); gtk_dialog_run (GTK_DIALOG (dialog)); gtk_widget_destroy (dialog); } @@ -974,7 +1186,7 @@ ufficio_on_btn_orario_elimina_clicked (GtkButton *button, GTK_DIALOG_DESTROY_WITH_PARENT, GTK_MESSAGE_WARNING, GTK_BUTTONS_OK, - "Occorre prima selezionare un orario"); + "Occorre prima selezionare un orario."); gtk_dialog_run (GTK_DIALOG (dialog)); gtk_widget_destroy (dialog); } diff --git a/src/ufficiostanza.c b/src/ufficiostanza.c new file mode 100644 index 0000000..274d8e5 --- /dev/null +++ b/src/ufficiostanza.c @@ -0,0 +1,343 @@ +/* + * 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 "ufficiostanza.h" + +static void ufficio_stanza_class_init (UfficioStanzaClass *klass); +static void ufficio_stanza_init (UfficioStanza *ufficio_stanza); + +static void ufficio_stanza_carica (UfficioStanza *ufficio_stanza); +static void ufficio_stanza_salva (UfficioStanza *ufficio_stanza); + +static gboolean ufficio_stanza_conferma_chiusura (UfficioStanza *ufficio_stanza); + +static void ufficio_stanza_set_property (GObject *object, + guint property_id, + const GValue *value, + GParamSpec *pspec); +static void ufficio_stanza_get_property (GObject *object, + guint property_id, + GValue *value, + GParamSpec *pspec); + +static gboolean ufficio_stanza_on_w_ufficio_stanza_delete_event (GtkWidget *widget, + GdkEvent *event, + gpointer user_data); + +static void ufficio_stanza_on_btn_annulla_clicked (GtkButton *button, + gpointer user_data); +static void ufficio_stanza_on_btn_salva_clicked (GtkButton *button, + gpointer user_data); + + +#define UFFICIO_STANZA_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), TYPE_UFFICIO_STANZA, UfficioStanzaPrivate)) + +enum +{ + LBL_ID, + LBL_ID_UFFICI +}; + +typedef struct _UfficioStanzaPrivate UfficioStanzaPrivate; +struct _UfficioStanzaPrivate + { + Commons *commons; + + GtkForm *form; + + GtkWidget *w; + + GObject **objects; + + guint id; + }; + +G_DEFINE_TYPE (UfficioStanza, ufficio_stanza, G_TYPE_OBJECT) + +static void +ufficio_stanza_class_init (UfficioStanzaClass *klass) +{ + GObjectClass *object_class = G_OBJECT_CLASS (klass); + + g_type_class_add_private (object_class, sizeof (UfficioStanzaPrivate)); + + object_class->set_property = ufficio_stanza_set_property; + object_class->get_property = ufficio_stanza_get_property; + + /** + * UfficioStanza::aggiornato: + * @ufficio_stanza: + * + */ + 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 +ufficio_stanza_init (UfficioStanza *ufficio_stanza) +{ + UfficioStanzaPrivate *priv = UFFICIO_STANZA_GET_PRIVATE (ufficio_stanza); +} + +/** + * ufficio_stanza_new: + * @commons: + * @id: + * @id_uffici: + * + * Returns: the newly created #UfficioStanza object. + */ +UfficioStanza +*ufficio_stanza_new (Commons *commons, guint id, guint id_uffici) +{ + GError *error; + + UfficioStanza *a = UFFICIO_STANZA (g_object_new (ufficio_stanza_get_type (), NULL)); + + UfficioStanzaPrivate *priv = UFFICIO_STANZA_GET_PRIVATE (a); + + priv->commons = commons; + + error = NULL; + + gtk_builder_add_objects_from_file (priv->commons->gtkbuilder, priv->commons->guifile, + g_strsplit ("w_ufficio_stanza", "|", -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, "ufficio_stanza.form", NULL), priv->commons->gtkbuilder); + + priv->w = GTK_WIDGET (gtk_builder_get_object (priv->commons->gtkbuilder, "w_ufficio_stanza")); + + priv->objects = gtk_form_get_objects_by_name (priv->form, + "label163", + "label164", + NULL); + + g_signal_connect (priv->w, + "delete-event", G_CALLBACK (ufficio_stanza_on_w_ufficio_stanza_delete_event), (gpointer *)a); + + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button138")), + "clicked", G_CALLBACK (ufficio_stanza_on_btn_annulla_clicked), (gpointer *)a); + g_signal_connect (G_OBJECT (gtk_builder_get_object (priv->commons->gtkbuilder, "button139")), + "clicked", G_CALLBACK (ufficio_stanza_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_UFFICI]), g_strdup_printf ("%d", id_uffici)); + + gtk_form_set_as_origin (priv->form); + } + else + { + gtk_label_set_text (GTK_LABEL (priv->objects[LBL_ID]), g_strdup_printf ("%d", priv->id)); + + ufficio_stanza_carica (a); + } + + return a; +} + +/** + * ufficio_stanza_get_widget: + * @ufficio_stanza: + * + */ +GtkWidget +*ufficio_stanza_get_widget (UfficioStanza *ufficio_stanza) +{ + UfficioStanzaPrivate *priv = UFFICIO_STANZA_GET_PRIVATE (ufficio_stanza); + + return priv->w; +} + +/* PRIVATE */ +static void +ufficio_stanza_carica (UfficioStanza *ufficio_stanza) +{ + gchar *sql; + GdaDataModel *dm; + + UfficioStanzaPrivate *priv = UFFICIO_STANZA_GET_PRIVATE (ufficio_stanza); + + if (gtk_form_fill_from_table (priv->form)) + { + } +} + +static void +ufficio_stanza_salva (UfficioStanza *ufficio_stanza) +{ + gchar *sql; + GtkWidget *dialog; + + UfficioStanzaClass *klass = UFFICIO_STANZA_GET_CLASS (ufficio_stanza); + + UfficioStanzaPrivate *priv = UFFICIO_STANZA_GET_PRIVATE (ufficio_stanza); + + 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 (ufficio_stanza, 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 +ufficio_stanza_set_property (GObject *object, guint property_id, const GValue *value, GParamSpec *pspec) +{ + UfficioStanza *ufficio_stanza = UFFICIO_STANZA (object); + + UfficioStanzaPrivate *priv = UFFICIO_STANZA_GET_PRIVATE (ufficio_stanza); + + switch (property_id) + { + default: + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); + break; + } +} + +static void +ufficio_stanza_get_property (GObject *object, guint property_id, GValue *value, GParamSpec *pspec) +{ + UfficioStanza *ufficio_stanza = UFFICIO_STANZA (object); + + UfficioStanzaPrivate *priv = UFFICIO_STANZA_GET_PRIVATE (ufficio_stanza); + + switch (property_id) + { + default: + G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); + break; + } +} + +static gboolean +ufficio_stanza_conferma_chiusura (UfficioStanza *ufficio_stanza) +{ + GtkWidget *dialog; + + gboolean ret; + + UfficioStanzaPrivate *priv = UFFICIO_STANZA_GET_PRIVATE (ufficio_stanza); + + 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 +ufficio_stanza_on_w_ufficio_stanza_delete_event (GtkWidget *widget, + GdkEvent *event, + gpointer user_data) +{ + return !ufficio_stanza_conferma_chiusura ((UfficioStanza *)user_data); +} + +static void +ufficio_stanza_on_btn_annulla_clicked (GtkButton *button, + gpointer user_data) +{ + UfficioStanza *ufficio_stanza = (UfficioStanza *)user_data; + + UfficioStanzaPrivate *priv = UFFICIO_STANZA_GET_PRIVATE (ufficio_stanza); + + if (ufficio_stanza_conferma_chiusura (ufficio_stanza)) gtk_widget_destroy (priv->w); +} + +static void +ufficio_stanza_on_btn_salva_clicked (GtkButton *button, + gpointer user_data) +{ + ufficio_stanza_salva ((UfficioStanza *)user_data); +} diff --git a/src/ufficiostanza.h b/src/ufficiostanza.h new file mode 100644 index 0000000..b29256e --- /dev/null +++ b/src/ufficiostanza.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 __UFFICIO_STANZA_H__ +#define __UFFICIO_STANZA_H__ + +#include +#include + +#include + +#include "commons.h" + +G_BEGIN_DECLS + + +#define TYPE_UFFICIO_STANZA (ufficio_stanza_get_type ()) +#define UFFICIO_STANZA(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_UFFICIO_STANZA, UfficioStanza)) +#define UFFICIO_STANZA_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_UFFICIO_STANZA, UfficioStanzaClass)) +#define IS_UFFICIO_STANZA(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_UFFICIO_STANZA)) +#define IS_UFFICIO_STANZA_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_UFFICIO_STANZA)) +#define UFFICIO_STANZA_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_UFFICIO_STANZA, UfficioStanzaClass)) + + +typedef struct _UfficioStanza UfficioStanza; +typedef struct _UfficioStanzaClass UfficioStanzaClass; + +struct _UfficioStanza + { + GObject parent; + }; + +struct _UfficioStanzaClass + { + GObjectClass parent_class; + + guint aggiornato_signal_id; + }; + +GType ufficio_stanza_get_type (void) G_GNUC_CONST; + +UfficioStanza *ufficio_stanza_new (Commons *commons, guint id, guint id_uffici); + +GtkWidget *ufficio_stanza_get_widget (UfficioStanza *ufficio_stanza); + + +G_END_DECLS + +#endif /* __UFFICIO_STANZA_H__ */