]> saetta.ns0.it Git - solipa/organigramma/commitdiff
Gestione stanze dell'ufficio.
authorAndrea Zagli <a.zagli@comune.scandicci.fi.it>
Tue, 19 Oct 2010 09:44:56 +0000 (11:44 +0200)
committerAndrea Zagli <a.zagli@comune.scandicci.fi.it>
Tue, 19 Oct 2010 09:44:56 +0000 (11:44 +0200)
data/organigramma/form/Makefile.am
data/organigramma/form/ufficio_stanza.form [new file with mode: 0644]
data/organigramma/gui/organigramma.gui
docs/organigramma.sql
src/Makefile.am
src/ufficio.c
src/ufficiostanza.c [new file with mode: 0644]
src/ufficiostanza.h [new file with mode: 0644]

index 942fd342298433da8d0c7153fcb43675922545b8..72cf39c2ca27a48bec5fa3141ea040c8ab13c9fb 100644 (file)
@@ -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 (file)
index 0000000..3dd2736
--- /dev/null
@@ -0,0 +1,37 @@
+<?xml version="1.0"?>
+<gtkform>
+
+       <table>ufficio_stanze</table>
+
+       <widget type="label" name="label163">
+               <field type="integer" name="id">
+                       <is-key>t</is-key>
+                       <auto-increment>t</auto-increment>
+               </field>
+       </widget>
+
+       <widget type="label" name="label164">
+               <field type="integer" name="id_uffici">
+               </field>
+       </widget>
+
+       <widget type="entry" name="entry44" label="label165">
+               <field type="text" name="piano">
+               </field>
+       </widget>
+
+       <widget type="entry" name="entry43" label="label161">
+               <field type="text" name="da_stanza">
+               </field>
+       </widget>
+
+       <widget type="entry" name="entry45" label="label162">
+               <field type="text" name="a_stanza">
+               </field>
+       </widget>
+
+       <widget type="textview" name="textview16" label="label160">
+               <field type="text" name="note" />
+       </widget>
+
+</gtkform>
index d1ef4b37596ebdfe29a68a2b8a5ddd037ee316d0..cec3279a914c9d70fb104256d0c2e958ad1854ee 100644 (file)
       <column type="gchararray"/>
     </columns>
   </object>
+  <object class="GtkListStore" id="lstore_ufficio_stanze">
+    <columns>
+      <!-- column-name id -->
+      <column type="guint"/>
+      <!-- column-name piano -->
+      <column type="gchararray"/>
+      <!-- column-name da_stanza -->
+      <column type="gchararray"/>
+      <!-- column-name a_stanza -->
+      <column type="gchararray"/>
+    </columns>
+  </object>
   <object class="GtkWindow" id="w_nodi">
     <property name="modal">True</property>
     <property name="window_position">center-on-parent</property>
         <child>
           <object class="GtkTable" id="table4">
             <property name="visible">True</property>
-            <property name="n_rows">7</property>
+            <property name="n_rows">8</property>
             <property name="n_columns">2</property>
             <property name="column_spacing">5</property>
             <property name="row_spacing">5</property>
                 <property name="label" translatable="yes">Nome</property>
               </object>
               <packing>
-                <property name="top_attach">3</property>
-                <property name="bottom_attach">4</property>
+                <property name="top_attach">4</property>
+                <property name="bottom_attach">5</property>
                 <property name="x_options">GTK_FILL</property>
                 <property name="y_options">GTK_FILL</property>
               </packing>
               <packing>
                 <property name="left_attach">1</property>
                 <property name="right_attach">2</property>
-                <property name="top_attach">3</property>
-                <property name="bottom_attach">4</property>
+                <property name="top_attach">4</property>
+                <property name="bottom_attach">5</property>
                 <property name="y_options">GTK_FILL</property>
               </packing>
             </child>
                 <property name="label" translatable="yes">Descrizione</property>
               </object>
               <packing>
-                <property name="top_attach">4</property>
-                <property name="bottom_attach">5</property>
+                <property name="top_attach">5</property>
+                <property name="bottom_attach">6</property>
                 <property name="x_options">GTK_FILL</property>
                 <property name="y_options">GTK_FILL</property>
               </packing>
               <packing>
                 <property name="left_attach">1</property>
                 <property name="right_attach">2</property>
-                <property name="top_attach">4</property>
-                <property name="bottom_attach">5</property>
+                <property name="top_attach">5</property>
+                <property name="bottom_attach">6</property>
               </packing>
             </child>
             <child>
               </object>
               <packing>
                 <property name="right_attach">2</property>
-                <property name="top_attach">5</property>
-                <property name="bottom_attach">6</property>
+                <property name="top_attach">6</property>
+                <property name="bottom_attach">7</property>
               </packing>
             </child>
             <child>
               </object>
               <packing>
                 <property name="right_attach">2</property>
-                <property name="top_attach">6</property>
-                <property name="bottom_attach">7</property>
+                <property name="top_attach">7</property>
+                <property name="bottom_attach">8</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkFrame" id="frame12">
+                <property name="visible">True</property>
+                <property name="label_xalign">0</property>
+                <child>
+                  <object class="GtkAlignment" id="alignment12">
+                    <property name="visible">True</property>
+                    <property name="left_padding">12</property>
+                    <child>
+                      <object class="GtkHBox" id="hbox19">
+                        <property name="visible">True</property>
+                        <property name="spacing">5</property>
+                        <child>
+                          <object class="GtkScrolledWindow" id="scrolledwindow39">
+                            <property name="visible">True</property>
+                            <property name="can_focus">True</property>
+                            <property name="hscrollbar_policy">automatic</property>
+                            <property name="vscrollbar_policy">automatic</property>
+                            <property name="shadow_type">etched-in</property>
+                            <child>
+                              <object class="GtkTreeView" id="treeview23">
+                                <property name="visible">True</property>
+                                <property name="can_focus">True</property>
+                                <property name="model">lstore_ufficio_stanze</property>
+                                <property name="headers_clickable">False</property>
+                                <property name="search_column">0</property>
+                                <child>
+                                  <object class="GtkTreeViewColumn" id="treeviewcolumn36">
+                                    <property name="title">Piano</property>
+                                    <child>
+                                      <object class="GtkCellRendererText" id="cellrenderertext47"/>
+                                      <attributes>
+                                        <attribute name="text">1</attribute>
+                                      </attributes>
+                                    </child>
+                                  </object>
+                                </child>
+                                <child>
+                                  <object class="GtkTreeViewColumn" id="treeviewcolumn37">
+                                    <property name="title">Da stanza</property>
+                                    <child>
+                                      <object class="GtkCellRendererText" id="cellrenderertext48"/>
+                                      <attributes>
+                                        <attribute name="text">2</attribute>
+                                      </attributes>
+                                    </child>
+                                  </object>
+                                </child>
+                                <child>
+                                  <object class="GtkTreeViewColumn" id="treeviewcolumn38">
+                                    <property name="title">A stanza</property>
+                                    <child>
+                                      <object class="GtkCellRendererText" id="cellrenderertext49"/>
+                                      <attributes>
+                                        <attribute name="text">3</attribute>
+                                      </attributes>
+                                    </child>
+                                  </object>
+                                </child>
+                              </object>
+                            </child>
+                          </object>
+                          <packing>
+                            <property name="position">0</property>
+                          </packing>
+                        </child>
+                        <child>
+                          <object class="GtkVButtonBox" id="vbuttonbox11">
+                            <property name="visible">True</property>
+                            <property name="spacing">5</property>
+                            <property name="layout_style">start</property>
+                            <child>
+                              <object class="GtkButton" id="button137">
+                                <property name="label">gtk-new</property>
+                                <property name="visible">True</property>
+                                <property name="can_focus">True</property>
+                                <property name="receives_default">True</property>
+                                <property name="use_stock">True</property>
+                              </object>
+                              <packing>
+                                <property name="expand">False</property>
+                                <property name="fill">False</property>
+                                <property name="position">0</property>
+                              </packing>
+                            </child>
+                            <child>
+                              <object class="GtkButton" id="button140">
+                                <property name="label">gtk-edit</property>
+                                <property name="visible">True</property>
+                                <property name="can_focus">True</property>
+                                <property name="receives_default">True</property>
+                                <property name="use_stock">True</property>
+                              </object>
+                              <packing>
+                                <property name="expand">False</property>
+                                <property name="fill">False</property>
+                                <property name="position">1</property>
+                              </packing>
+                            </child>
+                            <child>
+                              <object class="GtkButton" id="button141">
+                                <property name="label">gtk-delete</property>
+                                <property name="visible">True</property>
+                                <property name="can_focus">True</property>
+                                <property name="receives_default">True</property>
+                                <property name="use_stock">True</property>
+                              </object>
+                              <packing>
+                                <property name="expand">False</property>
+                                <property name="fill">False</property>
+                                <property name="position">2</property>
+                              </packing>
+                            </child>
+                          </object>
+                          <packing>
+                            <property name="expand">False</property>
+                            <property name="position">1</property>
+                          </packing>
+                        </child>
+                      </object>
+                    </child>
+                  </object>
+                </child>
+                <child type="label">
+                  <object class="GtkLabel" id="label166">
+                    <property name="visible">True</property>
+                    <property name="label" translatable="yes">&lt;b&gt;Stanze&lt;/b&gt;</property>
+                    <property name="use_markup">True</property>
+                  </object>
+                </child>
+              </object>
+              <packing>
+                <property name="right_attach">2</property>
+                <property name="top_attach">3</property>
+                <property name="bottom_attach">4</property>
               </packing>
             </child>
           </object>
       </object>
     </child>
   </object>
+  <object class="GtkWindow" id="w_ufficio_stanza">
+    <property name="title" translatable="yes">Stanze dell'ufficio - Gestione organigramma</property>
+    <property name="modal">True</property>
+    <property name="window_position">center-on-parent</property>
+    <property name="destroy_with_parent">True</property>
+    <child>
+      <object class="GtkVBox" id="vbox25">
+        <property name="visible">True</property>
+        <property name="border_width">5</property>
+        <property name="orientation">vertical</property>
+        <property name="spacing">5</property>
+        <child>
+          <object class="GtkTable" id="table23">
+            <property name="visible">True</property>
+            <property name="n_rows">5</property>
+            <property name="n_columns">2</property>
+            <property name="column_spacing">5</property>
+            <property name="row_spacing">5</property>
+            <child>
+              <object class="GtkLabel" id="label160">
+                <property name="visible">True</property>
+                <property name="xalign">0</property>
+                <property name="yalign">0</property>
+                <property name="label" translatable="yes">Note</property>
+              </object>
+              <packing>
+                <property name="top_attach">3</property>
+                <property name="bottom_attach">4</property>
+                <property name="x_options">GTK_FILL</property>
+                <property name="y_options">GTK_FILL</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkScrolledWindow" id="scrolledwindow38">
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="hscrollbar_policy">automatic</property>
+                <property name="vscrollbar_policy">automatic</property>
+                <property name="shadow_type">etched-in</property>
+                <child>
+                  <object class="GtkTextView" id="textview16">
+                    <property name="visible">True</property>
+                    <property name="can_focus">True</property>
+                  </object>
+                </child>
+              </object>
+              <packing>
+                <property name="left_attach">1</property>
+                <property name="right_attach">2</property>
+                <property name="top_attach">3</property>
+                <property name="bottom_attach">4</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkLabel" id="label161">
+                <property name="visible">True</property>
+                <property name="xalign">0</property>
+                <property name="label" translatable="yes">Da stanza</property>
+              </object>
+              <packing>
+                <property name="top_attach">1</property>
+                <property name="bottom_attach">2</property>
+                <property name="x_options">GTK_FILL</property>
+                <property name="y_options">GTK_FILL</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkLabel" id="label163">
+                <property name="xalign">0</property>
+                <property name="label" translatable="yes">lbl_id</property>
+              </object>
+              <packing>
+                <property name="top_attach">4</property>
+                <property name="bottom_attach">5</property>
+                <property name="x_options">GTK_FILL</property>
+                <property name="y_options">GTK_FILL</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkLabel" id="label164">
+                <property name="label" translatable="yes">lbl_id_uffici</property>
+              </object>
+              <packing>
+                <property name="left_attach">1</property>
+                <property name="right_attach">2</property>
+                <property name="top_attach">4</property>
+                <property name="bottom_attach">5</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkLabel" id="label165">
+                <property name="visible">True</property>
+                <property name="xalign">0</property>
+                <property name="label" translatable="yes">Piano</property>
+              </object>
+              <packing>
+                <property name="x_options">GTK_FILL</property>
+                <property name="y_options">GTK_FILL</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkEntry" id="entry44">
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="max_length">10</property>
+                <property name="invisible_char">&#x25CF;</property>
+              </object>
+              <packing>
+                <property name="left_attach">1</property>
+                <property name="right_attach">2</property>
+                <property name="y_options">GTK_FILL</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkEntry" id="entry43">
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="max_length">10</property>
+                <property name="invisible_char">&#x25CF;</property>
+              </object>
+              <packing>
+                <property name="left_attach">1</property>
+                <property name="right_attach">2</property>
+                <property name="top_attach">1</property>
+                <property name="bottom_attach">2</property>
+                <property name="y_options">GTK_FILL</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkLabel" id="label162">
+                <property name="visible">True</property>
+                <property name="xalign">0</property>
+                <property name="label" translatable="yes">A stanza</property>
+              </object>
+              <packing>
+                <property name="top_attach">2</property>
+                <property name="bottom_attach">3</property>
+                <property name="x_options">GTK_FILL</property>
+                <property name="y_options">GTK_FILL</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkEntry" id="entry45">
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="max_length">10</property>
+                <property name="invisible_char">&#x25CF;</property>
+              </object>
+              <packing>
+                <property name="left_attach">1</property>
+                <property name="right_attach">2</property>
+                <property name="top_attach">2</property>
+                <property name="bottom_attach">3</property>
+                <property name="y_options">GTK_FILL</property>
+              </packing>
+            </child>
+          </object>
+          <packing>
+            <property name="position">0</property>
+          </packing>
+        </child>
+        <child>
+          <object class="GtkHButtonBox" id="hbuttonbox34">
+            <property name="visible">True</property>
+            <property name="spacing">5</property>
+            <property name="layout_style">end</property>
+            <child>
+              <object class="GtkButton" id="button138">
+                <property name="label">gtk-cancel</property>
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="receives_default">True</property>
+                <property name="use_stock">True</property>
+              </object>
+              <packing>
+                <property name="expand">False</property>
+                <property name="fill">False</property>
+                <property name="position">0</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkButton" id="button139">
+                <property name="label">gtk-save</property>
+                <property name="visible">True</property>
+                <property name="can_focus">True</property>
+                <property name="receives_default">True</property>
+                <property name="use_stock">True</property>
+              </object>
+              <packing>
+                <property name="expand">False</property>
+                <property name="fill">False</property>
+                <property name="position">1</property>
+              </packing>
+            </child>
+          </object>
+          <packing>
+            <property name="expand">False</property>
+            <property name="position">1</property>
+          </packing>
+        </child>
+      </object>
+    </child>
+  </object>
 </interface>
index 6f1a76d9786c705c8addb85f0e0ef9b0a6c73bfd..08ad05cc488cccf0019202afc837113b51905346 100644 (file)
@@ -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
index fbd890f449fb0e3245a6f038dce0401f7c8f5515..a362377801fae5f4d7c784aa91f470f50495cd56 100644 (file)
@@ -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
index c7108afddd80fd9362c43639d6922a428fba888f..085a7121b10bb86a6e6cc661f80344827dd77cd5 100644 (file)
@@ -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 (file)
index 0000000..274d8e5
--- /dev/null
@@ -0,0 +1,343 @@
+/* 
+ * Copyright (C) 2009 Andrea Zagli <azagli@libero.it>
+ *
+ * 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 <config.h>
+#endif
+
+#include <libgtkform/form.h>
+
+#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 (file)
index 0000000..b29256e
--- /dev/null
@@ -0,0 +1,65 @@
+/* 
+ * Copyright (C) 2009 Andrea Zagli <azagli@libero.it>
+ *
+ * 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 <glib.h>
+#include <glib-object.h>
+
+#include <gtk/gtk.h>
+
+#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__ */