Ricerche varie (da maschera e su digitazione).
authorAndrea Zagli <a.zagli@comune.scandicci.fi.it>
Tue, 26 Oct 2010 14:29:09 +0000 (16:29 +0200)
committerAndrea Zagli <a.zagli@comune.scandicci.fi.it>
Tue, 26 Oct 2010 14:29:09 +0000 (16:29 +0200)
16 files changed:
data/territorio/form/Makefile.am
data/territorio/form/ricerca_comuni.form [new file with mode: 0644]
data/territorio/form/ricerca_province.form [new file with mode: 0644]
data/territorio/form/ricerca_vie.form [new file with mode: 0644]
data/territorio/gui/territorio.gui
libreria/Makefile.am
src/Makefile.am
src/comuni.c
src/province.c
src/ricercacomuni.c [new file with mode: 0644]
src/ricercacomuni.h [new file with mode: 0644]
src/ricercaprovince.c [new file with mode: 0644]
src/ricercaprovince.h [new file with mode: 0644]
src/ricercavie.c [new file with mode: 0644]
src/ricercavie.h [new file with mode: 0644]
src/vie.c

index 0c41989ebfa68e80161e90d0bc6ee6e2a2ccf9d0..b726183f4626ca32c1076a0b43263e794f757585 100644 (file)
@@ -5,6 +5,9 @@ form_DATA = \
             comune.form \
             provincia.form \
             regione.form \
+            ricerca_comuni.form \
+            ricerca_province.form \
+            ricerca_vie.form \
             stato.form \
             tipo_aggregazione_territoriale.form \
             via.form
diff --git a/data/territorio/form/ricerca_comuni.form b/data/territorio/form/ricerca_comuni.form
new file mode 100644 (file)
index 0000000..44123f4
--- /dev/null
@@ -0,0 +1,24 @@
+<?xml version="1.0"?>
+<gtkform>
+
+       <widget type="entry" name="entry21" label="label43">
+               <field type="text" name="nome">
+               </field>
+       </widget>
+
+       <widget type="entry" name="entry22">
+               <field type="text" name="provincia">
+               </field>
+       </widget>
+
+       <widget type="label" name="label48" label="label47">
+               <on-change what="update" when="after">
+                       <widget-name>entry22</widget-name>
+                       <sql>
+                               SELECT nome FROM province WHERE id = ##label48::gint
+                       </sql>
+               </on-change>
+               <field type="integer" name="id_province" />
+       </widget>
+
+</gtkform>
diff --git a/data/territorio/form/ricerca_province.form b/data/territorio/form/ricerca_province.form
new file mode 100644 (file)
index 0000000..f895067
--- /dev/null
@@ -0,0 +1,24 @@
+<?xml version="1.0"?>
+<gtkform>
+
+       <widget type="entry" name="entry18" label="label56">
+               <field type="text" name="nome">
+               </field>
+       </widget>
+
+       <widget type="entry" name="entry23">
+               <field type="text" name="regione">
+               </field>
+       </widget>
+
+       <widget type="label" name="label60" label="label59">
+               <on-change what="update" when="after">
+                       <widget-name>entry23</widget-name>
+                       <sql>
+                               SELECT nome FROM regioni WHERE id = ##label60::gint
+                       </sql>
+               </on-change>
+               <field type="integer" name="id_regioni" />
+       </widget>
+
+</gtkform>
diff --git a/data/territorio/form/ricerca_vie.form b/data/territorio/form/ricerca_vie.form
new file mode 100644 (file)
index 0000000..600431d
--- /dev/null
@@ -0,0 +1,24 @@
+<?xml version="1.0"?>
+<gtkform>
+
+       <widget type="entry" name="entry24" label="label49">
+               <field type="text" name="nome">
+               </field>
+       </widget>
+
+       <widget type="entry" name="entry25">
+               <field type="text" name="comune">
+               </field>
+       </widget>
+
+       <widget type="label" name="label51" label="label50">
+               <on-change what="update" when="after">
+                       <widget-name>entry25</widget-name>
+                       <sql>
+                               SELECT nome FROM comuni WHERE id = ##label51::gint
+                       </sql>
+               </on-change>
+               <field type="integer" name="id_comuni" />
+       </widget>
+
+</gtkform>
index 72e1a49f0e5e04f6858aa047df23f1f491551904..5fcb62fb137f21675c6302583da451deb90b83c6 100644 (file)
                 <property name="visible">True</property>
                 <property name="can_focus">True</property>
                 <property name="model">lstore_stati</property>
+                <property name="search_column">1</property>
                 <child>
                   <object class="GtkTreeViewColumn" id="treeviewcolumn2">
                     <property name="title">Nome</property>
                 <property name="visible">True</property>
                 <property name="can_focus">True</property>
                 <property name="model">lstore_regioni</property>
+                <property name="search_column">1</property>
                 <child>
                   <object class="GtkTreeViewColumn" id="treeviewcolumn1">
                     <property name="title">Nome</property>
                 <property name="visible">True</property>
                 <property name="can_focus">True</property>
                 <property name="model">lstore_province</property>
+                <property name="search_column">1</property>
                 <child>
                   <object class="GtkTreeViewColumn" id="treeviewcolumn3">
                     <property name="title">Nome</property>
                 <property name="position">2</property>
               </packing>
             </child>
+            <child>
+              <object class="GtkButton" id="button53">
+                <property name="label">gtk-find</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">3</property>
+              </packing>
+            </child>
             <child>
               <object class="GtkButton" id="button18">
                 <property name="label">gtk-cancel</property>
               <packing>
                 <property name="expand">False</property>
                 <property name="fill">False</property>
-                <property name="position">3</property>
+                <property name="position">4</property>
               </packing>
             </child>
             <child>
               <packing>
                 <property name="expand">False</property>
                 <property name="fill">False</property>
-                <property name="position">4</property>
+                <property name="position">5</property>
               </packing>
             </child>
           </object>
                 <property name="visible">True</property>
                 <property name="can_focus">True</property>
                 <property name="model">lstore_comuni</property>
+                <property name="search_column">1</property>
                 <child>
                   <object class="GtkTreeViewColumn" id="treeviewcolumn4">
                     <property name="title">Nome</property>
                 <property name="position">2</property>
               </packing>
             </child>
+            <child>
+              <object class="GtkButton" id="button58">
+                <property name="label">gtk-find</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">3</property>
+              </packing>
+            </child>
             <child>
               <object class="GtkButton" id="button25">
                 <property name="label">gtk-cancel</property>
               <packing>
                 <property name="expand">False</property>
                 <property name="fill">False</property>
-                <property name="position">3</property>
+                <property name="position">4</property>
               </packing>
             </child>
             <child>
               <packing>
                 <property name="expand">False</property>
                 <property name="fill">False</property>
-                <property name="position">4</property>
+                <property name="position">5</property>
               </packing>
             </child>
           </object>
                 <property name="can_focus">True</property>
                 <property name="max_length">150</property>
                 <property name="invisible_char">&#x25CF;</property>
+                <property name="text" translatable="yes">uu</property>
               </object>
               <packing>
                 <property name="left_attach">1</property>
                 <property name="can_focus">True</property>
                 <property name="model">lstore_vie</property>
                 <property name="headers_clickable">False</property>
-                <property name="search_column">0</property>
+                <property name="search_column">1</property>
                 <child>
                   <object class="GtkTreeViewColumn" id="treeviewcolumn7">
                     <property name="title">Nome</property>
                 <property name="position">2</property>
               </packing>
             </child>
+            <child>
+              <object class="GtkButton" id="button63">
+                <property name="label">gtk-find</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">3</property>
+              </packing>
+            </child>
             <child>
               <object class="GtkButton" id="button48">
                 <property name="label">gtk-cancel</property>
               <packing>
                 <property name="expand">False</property>
                 <property name="fill">False</property>
-                <property name="position">3</property>
+                <property name="position">4</property>
               </packing>
             </child>
             <child>
               <packing>
                 <property name="expand">False</property>
                 <property name="fill">False</property>
-                <property name="position">4</property>
+                <property name="position">5</property>
               </packing>
             </child>
           </object>
       </object>
     </child>
   </object>
+  <object class="GtkWindow" id="w_ricerca_province">
+    <property name="title" translatable="yes">Ricerca province - Territorio</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="vbox16">
+        <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="table9">
+            <property name="visible">True</property>
+            <property name="n_rows">2</property>
+            <property name="n_columns">2</property>
+            <property name="column_spacing">5</property>
+            <property name="row_spacing">5</property>
+            <child>
+              <object class="GtkLabel" id="label56">
+                <property name="visible">True</property>
+                <property name="xalign">0</property>
+                <property name="label" translatable="yes">Nome</property>
+              </object>
+              <packing>
+                <property name="x_options">GTK_FILL</property>
+                <property name="y_options">GTK_FILL</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkEntry" id="entry18">
+                <property name="visible">True</property>
+                <property name="can_focus">True</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="GtkLabel" id="label59">
+                <property name="visible">True</property>
+                <property name="xalign">0</property>
+                <property name="label" translatable="yes">Regione</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="GtkHBox" id="hbox10">
+                <property name="visible">True</property>
+                <property name="spacing">5</property>
+                <child>
+                  <object class="GtkEntry" id="entry23">
+                    <property name="visible">True</property>
+                    <property name="can_focus">True</property>
+                    <property name="editable">False</property>
+                    <property name="invisible_char">&#x25CF;</property>
+                  </object>
+                  <packing>
+                    <property name="position">0</property>
+                  </packing>
+                </child>
+                <child>
+                  <object class="GtkButton" id="button69">
+                    <property name="label" translatable="yes">...</property>
+                    <property name="visible">True</property>
+                    <property name="can_focus">True</property>
+                    <property name="receives_default">True</property>
+                  </object>
+                  <packing>
+                    <property name="expand">False</property>
+                    <property name="position">1</property>
+                  </packing>
+                </child>
+                <child>
+                  <object class="GtkLabel" id="label60">
+                    <property name="label" translatable="yes">lbl_id_regioni</property>
+                  </object>
+                  <packing>
+                    <property name="expand">False</property>
+                    <property name="position">2</property>
+                  </packing>
+                </child>
+              </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>
+          </object>
+          <packing>
+            <property name="position">0</property>
+          </packing>
+        </child>
+        <child>
+          <object class="GtkHButtonBox" id="hbuttonbox16">
+            <property name="visible">True</property>
+            <property name="spacing">5</property>
+            <property name="layout_style">end</property>
+            <child>
+              <object class="GtkButton" id="button70">
+                <property name="label">gtk-clear</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="button67">
+                <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">1</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkButton" id="button68">
+                <property name="label">gtk-ok</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>
+  <object class="GtkWindow" id="w_ricerca_comuni">
+    <property name="title" translatable="yes">Ricerca comuni - Territorio</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="vbox17">
+        <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="table8">
+            <property name="visible">True</property>
+            <property name="n_rows">2</property>
+            <property name="n_columns">2</property>
+            <property name="column_spacing">5</property>
+            <property name="row_spacing">5</property>
+            <child>
+              <object class="GtkLabel" id="label43">
+                <property name="visible">True</property>
+                <property name="xalign">0</property>
+                <property name="label" translatable="yes">Nome</property>
+              </object>
+              <packing>
+                <property name="x_options">GTK_FILL</property>
+                <property name="y_options">GTK_FILL</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkEntry" id="entry21">
+                <property name="visible">True</property>
+                <property name="can_focus">True</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="GtkLabel" id="label47">
+                <property name="visible">True</property>
+                <property name="xalign">0</property>
+                <property name="label" translatable="yes">Provincia</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="GtkHBox" id="hbox4">
+                <property name="visible">True</property>
+                <property name="spacing">5</property>
+                <child>
+                  <object class="GtkEntry" id="entry22">
+                    <property name="visible">True</property>
+                    <property name="can_focus">True</property>
+                    <property name="editable">False</property>
+                    <property name="invisible_char">&#x25CF;</property>
+                  </object>
+                  <packing>
+                    <property name="position">0</property>
+                  </packing>
+                </child>
+                <child>
+                  <object class="GtkButton" id="button54">
+                    <property name="label" translatable="yes">...</property>
+                    <property name="visible">True</property>
+                    <property name="can_focus">True</property>
+                    <property name="receives_default">True</property>
+                  </object>
+                  <packing>
+                    <property name="expand">False</property>
+                    <property name="position">1</property>
+                  </packing>
+                </child>
+                <child>
+                  <object class="GtkLabel" id="label48">
+                    <property name="label" translatable="yes">lbl_id_province</property>
+                  </object>
+                  <packing>
+                    <property name="expand">False</property>
+                    <property name="position">2</property>
+                  </packing>
+                </child>
+              </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>
+          </object>
+          <packing>
+            <property name="position">0</property>
+          </packing>
+        </child>
+        <child>
+          <object class="GtkHButtonBox" id="hbuttonbox15">
+            <property name="visible">True</property>
+            <property name="spacing">5</property>
+            <property name="layout_style">end</property>
+            <child>
+              <object class="GtkButton" id="button55">
+                <property name="label">gtk-clear</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="button56">
+                <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">1</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkButton" id="button57">
+                <property name="label">gtk-ok</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>
+  <object class="GtkWindow" id="w_ricerca_vie">
+    <property name="title" translatable="yes">Ricerca vie - Territorio</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="vbox18">
+        <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="table10">
+            <property name="visible">True</property>
+            <property name="n_rows">2</property>
+            <property name="n_columns">2</property>
+            <property name="column_spacing">5</property>
+            <property name="row_spacing">5</property>
+            <child>
+              <object class="GtkLabel" id="label49">
+                <property name="visible">True</property>
+                <property name="xalign">0</property>
+                <property name="label" translatable="yes">Nome</property>
+              </object>
+              <packing>
+                <property name="x_options">GTK_FILL</property>
+                <property name="y_options">GTK_FILL</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkEntry" id="entry24">
+                <property name="visible">True</property>
+                <property name="can_focus">True</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="GtkLabel" id="label50">
+                <property name="visible">True</property>
+                <property name="xalign">0</property>
+                <property name="label" translatable="yes">Comune</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="GtkHBox" id="hbox5">
+                <property name="visible">True</property>
+                <property name="spacing">5</property>
+                <child>
+                  <object class="GtkEntry" id="entry25">
+                    <property name="visible">True</property>
+                    <property name="can_focus">True</property>
+                    <property name="editable">False</property>
+                    <property name="invisible_char">&#x25CF;</property>
+                  </object>
+                  <packing>
+                    <property name="position">0</property>
+                  </packing>
+                </child>
+                <child>
+                  <object class="GtkButton" id="button59">
+                    <property name="label" translatable="yes">...</property>
+                    <property name="visible">True</property>
+                    <property name="can_focus">True</property>
+                    <property name="receives_default">True</property>
+                  </object>
+                  <packing>
+                    <property name="expand">False</property>
+                    <property name="position">1</property>
+                  </packing>
+                </child>
+                <child>
+                  <object class="GtkLabel" id="label51">
+                    <property name="label" translatable="yes">lbl_id_comuni</property>
+                  </object>
+                  <packing>
+                    <property name="expand">False</property>
+                    <property name="position">2</property>
+                  </packing>
+                </child>
+              </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>
+          </object>
+          <packing>
+            <property name="position">0</property>
+          </packing>
+        </child>
+        <child>
+          <object class="GtkHButtonBox" id="hbuttonbox17">
+            <property name="visible">True</property>
+            <property name="spacing">5</property>
+            <property name="layout_style">end</property>
+            <child>
+              <object class="GtkButton" id="button60">
+                <property name="label">gtk-clear</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="button61">
+                <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">1</property>
+              </packing>
+            </child>
+            <child>
+              <object class="GtkButton" id="button62">
+                <property name="label">gtk-ok</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>
 </interface>
index 1a65d2b16f6e3faba85027cae7fb55d29392eb96..f2d2a9386278f8c5424ae05c45596f61e38bb2d9 100644 (file)
@@ -19,6 +19,9 @@ libterritorio_la_SOURCES = \
                 ../src/provincia.c \
                 ../src/regione.c \
                 ../src/regioni.c \
+                ../src/ricercacomuni.c \
+                ../src/ricercaprovince.c \
+                ../src/ricercavie.c \
                 ../src/stati.c \
                 ../src/stato.c \
                 ../src/tipiaggregazioneterritoriale.c \
@@ -36,6 +39,9 @@ libterritorio_include_HEADERS = \
                 ../src/comuni.h \
                 ../src/province.h \
                 ../src/provincia.h \
+                ../src/ricercacomuni.h \
+                ../src/ricercaprovince.h \
+                ../src/ricercavie.h \
                 ../src/regione.h \
                 ../src/regioni.h \
                 ../src/stati.h \
index 150878b8c8264b88c0ddb9b56237ba843419a28c..4531b14f2611eb1a3ea06c1516488709ca8306d7 100644 (file)
@@ -31,6 +31,12 @@ territorio_SOURCES = \
                 regione.h \
                 regioni.c \
                 regioni.h \
+                ricercacomuni.c \
+                ricercacomuni.h \
+                ricercaprovince.c \
+                ricercaprovince.h \
+                ricercavie.c \
+                ricercavie.h \
                 stati.c \
                 stati.h \
                 stato.c \
index fc4e760b1be0865b06a6857407bbbd04e8ec2ad1..f9beb33f915c3cdaa5c6acb674871312c84678ef 100644 (file)
@@ -19,6 +19,7 @@
 
 #include "comuni.h"
 #include "comune.h"
+#include "ricercacomuni.h"
 
 static void territorio_comuni_class_init (TerritorioComuniClass *klass);
 static void territorio_comuni_init (TerritorioComuni *territorio_comuni);
@@ -29,6 +30,8 @@ static void territorio_comuni_modifica (TerritorioComuni *territorio_comuni);
 static void territorio_comuni_selezionato (TerritorioComuni *territorio_comuni);
 static void territorio_comuni_on_comune_aggiornato (gpointer instance, gpointer user_data);
 
+static void territorio_comuni_on_filtra (gpointer instance, gpointer parametri, gpointer user_data);
+
 static void territorio_comuni_set_property (GObject *object,
                                      guint property_id,
                                      const GValue *value,
@@ -49,6 +52,9 @@ static void territorio_comuni_on_trv_territorio_comuni_row_activated (GtkTreeVie
                                              GtkTreeViewColumn *column,
                                              gpointer user_data);
 
+static void territorio_comuni_on_btn_trova_clicked (GtkButton *button,
+                                    gpointer user_data);
+
 static void territorio_comuni_on_btn_annulla_clicked (GtkButton *button,
                                     gpointer user_data);
 static void territorio_comuni_on_btn_seleziona_clicked (GtkButton *button,
@@ -71,6 +77,8 @@ struct _TerritorioComuniPrivate
                GtkTreeSelection *selection;
                GtkListStore *lstore_comuni;
 
+               GHashTable *parametri_ricerca;
+
                gboolean selezione;
                GtkWindow *wtransient;
        };
@@ -161,6 +169,8 @@ TerritorioComuni
                          "clicked", G_CALLBACK (territorio_comuni_on_btn_elimina_clicked), (gpointer)a);
        g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview4"),
                          "row-activated", G_CALLBACK (territorio_comuni_on_trv_territorio_comuni_row_activated), (gpointer)a);
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button58"),
+                         "clicked", G_CALLBACK (territorio_comuni_on_btn_trova_clicked), (gpointer)a);
 
        if (priv->selezione)
                {
@@ -201,6 +211,13 @@ territorio_comuni_carica (TerritorioComuni *territorio_comuni)
        GtkTreeIter iter;
        GdaDataModel *dm;
 
+       gchar *sql;
+       gchar *sql_where;
+
+       GValue *gvalue;
+       gchar *gcval;
+       gint ival;
+
        gint rows;
        gint row;
 
@@ -208,11 +225,33 @@ territorio_comuni_carica (TerritorioComuni *territorio_comuni)
 
        gtk_list_store_clear (priv->lstore_comuni);
 
-       dm = gdaex_query (priv->commons->gdaex,
-                         "SELECT c.id, c.nome"
-                         " FROM comuni AS c"
-                         " WHERE c.status <> 'E'"
-                         " ORDER BY c.nome");
+       sql_where = g_strdup ("");
+       if (priv->parametri_ricerca != NULL)
+               {
+                       gcval = g_strstrip ((gchar *)g_value_get_string ((GValue *)g_hash_table_lookup (priv->parametri_ricerca, "nome")));
+                       if (g_strcmp0 (gcval, "") != 0)
+                               {
+                                       sql_where = g_strconcat (sql_where, " AND c.nome ILIKE '%",
+                                                                g_strdup_printf ("%s", gcval),
+                                                                "%'",
+                                                                NULL);
+                               }
+                       ival = g_value_get_int ((GValue *)g_hash_table_lookup (priv->parametri_ricerca, "id_province"));
+                       if (ival != 0)
+                               {
+                                       sql_where = g_strconcat (sql_where, " AND c.id_province = ",
+                                                                g_strdup_printf ("%d", ival),
+                                                                NULL);
+                               }
+               }
+
+       sql = g_strdup_printf ("SELECT c.id, c.nome"
+                              " FROM comuni AS c"
+                              " WHERE c.status <> 'E'"
+                              "%s"
+                              " ORDER BY c.nome",
+                              sql_where);
+       dm = gdaex_query (priv->commons->gdaex, sql);
        if (dm != NULL)
                {
                        rows = gda_data_model_get_n_rows (dm);
@@ -261,7 +300,7 @@ territorio_comuni_modifica (TerritorioComuni *territorio_comuni)
                                                                    GTK_DIALOG_DESTROY_WITH_PARENT,
                                                                    GTK_MESSAGE_WARNING,
                                                                    GTK_BUTTONS_OK,
-                                                                   "Occorre prima selezionare un comune");
+                                                                   "Occorre prima selezionare un comune.");
                        gtk_dialog_run (GTK_DIALOG (dialog));
                        gtk_widget_destroy (dialog);
                }
@@ -293,7 +332,7 @@ territorio_comuni_selezionato (TerritorioComuni *territorio_comuni)
                                                         GTK_DIALOG_DESTROY_WITH_PARENT,
                                                         GTK_MESSAGE_WARNING,
                                                         GTK_BUTTONS_OK,
-                                                        "Occorre prima selezionare un comune");
+                                                        "Occorre prima selezionare un comune.");
                        gtk_dialog_run (GTK_DIALOG (dialog));
                        gtk_widget_destroy (dialog);
                }
@@ -305,6 +344,17 @@ territorio_comuni_on_comune_aggiornato (gpointer instance, gpointer user_data)
        territorio_comuni_carica ((TerritorioComuni *)user_data);
 }
 
+static void
+territorio_comuni_on_filtra (gpointer instance, gpointer parametri, gpointer user_data)
+{
+       TerritorioComuni *i = (TerritorioComuni *)user_data;
+       TerritorioComuniPrivate *priv = TERRITORIO_COMUNI_GET_PRIVATE (i);
+
+       priv->parametri_ricerca = (GHashTable *)parametri;
+
+       territorio_comuni_carica (i);
+}
+
 static void
 territorio_comuni_set_property (GObject *object, guint property_id, const GValue *value, GParamSpec *pspec)
 {
@@ -427,6 +477,24 @@ territorio_comuni_on_trv_territorio_comuni_row_activated (GtkTreeView *tree_view
 }
 
 
+static void
+territorio_comuni_on_btn_trova_clicked (GtkButton *button,
+                        gpointer user_data)
+{
+       GtkWidget *w;
+
+       TerritorioComuniPrivate *priv = TERRITORIO_COMUNI_GET_PRIVATE ((TerritorioComuni *)user_data);
+
+       TerritorioRicercaComuni *rf = territorio_ricerca_comuni_new (priv->commons, priv->parametri_ricerca);
+
+       g_signal_connect (G_OBJECT (rf), "filtra",
+                         G_CALLBACK (territorio_comuni_on_filtra), (TerritorioComuni *)user_data);
+
+       w = territorio_ricerca_comuni_get_widget (rf);
+       gtk_window_set_transient_for (GTK_WINDOW (w), priv->wtransient);
+       gtk_widget_show (w);
+}
+
 static void
 territorio_comuni_on_btn_annulla_clicked (GtkButton *button,
                         gpointer user_data)
index ecb0607c1b4b208d73ced2d49138aa24d80d59bd..e78e5433ad0f167ce7f976a2939c630e71a1afb1 100644 (file)
@@ -19,6 +19,7 @@
 
 #include "province.h"
 #include "provincia.h"
+#include "ricercaprovince.h"
 
 static void territorio_province_class_init (TerritorioProvinceClass *klass);
 static void territorio_province_init (TerritorioProvince *territorio_province);
@@ -29,6 +30,8 @@ static void territorio_province_modifica (TerritorioProvince *territorio_provinc
 static void territorio_province_selezionato (TerritorioProvince *territorio_province);
 static void territorio_province_on_provincia_aggiornato (gpointer instance, gpointer user_data);
 
+static void territorio_province_on_filtra (gpointer instance, gpointer parametri, gpointer user_data);
+
 static void territorio_province_set_property (GObject *object,
                                      guint property_id,
                                      const GValue *value,
@@ -49,6 +52,9 @@ static void territorio_province_on_trv_territorio_province_row_activated (GtkTre
                                              GtkTreeViewColumn *column,
                                              gpointer user_data);
 
+static void territorio_province_on_btn_trova_clicked (GtkButton *button,
+                                    gpointer user_data);
+
 static void territorio_province_on_btn_annulla_clicked (GtkButton *button,
                                     gpointer user_data);
 static void territorio_province_on_btn_seleziona_clicked (GtkButton *button,
@@ -71,6 +77,8 @@ struct _TerritorioProvincePrivate
                GtkTreeSelection *selection;
                GtkListStore *lstore_province;
 
+               GHashTable *parametri_ricerca;
+
                gboolean selezione;
                GtkWindow *wtransient;
        };
@@ -161,6 +169,8 @@ TerritorioProvince
                          "clicked", G_CALLBACK (territorio_province_on_btn_elimina_clicked), (gpointer)a);
        g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview3"),
                          "row-activated", G_CALLBACK (territorio_province_on_trv_territorio_province_row_activated), (gpointer)a);
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button53"),
+                         "clicked", G_CALLBACK (territorio_province_on_btn_trova_clicked), (gpointer)a);
 
        if (priv->selezione)
                {
@@ -201,6 +211,13 @@ territorio_province_carica (TerritorioProvince *territorio_province)
        GtkTreeIter iter;
        GdaDataModel *dm;
 
+       gchar *sql;
+       gchar *sql_where;
+
+       GValue *gvalue;
+       gchar *gcval;
+       gint ival;
+
        gint rows;
        gint row;
 
@@ -208,11 +225,34 @@ territorio_province_carica (TerritorioProvince *territorio_province)
 
        gtk_list_store_clear (priv->lstore_province);
 
-       dm = gdaex_query (priv->commons->gdaex,
-                         "SELECT c.id, c.nome"
-                         " FROM province AS c"
-                         " WHERE c.status <> 'E'"
-                         " ORDER BY c.nome");
+       sql_where = g_strdup ("");
+       if (priv->parametri_ricerca != NULL)
+               {
+                       gcval = g_strstrip ((gchar *)g_value_get_string ((GValue *)g_hash_table_lookup (priv->parametri_ricerca, "nome")));
+                       if (g_strcmp0 (gcval, "") != 0)
+                               {
+                                       sql_where = g_strconcat (sql_where, " AND c.nome ILIKE '%",
+                                                                g_strdup_printf ("%s", gcval),
+                                                                "%'",
+                                                                NULL);
+                               }
+                       ival = g_value_get_int ((GValue *)g_hash_table_lookup (priv->parametri_ricerca, "id_regioni"));
+                       if (ival != 0)
+                               {
+                                       sql_where = g_strconcat (sql_where, " AND c.id_regioni = ",
+                                                                g_strdup_printf ("%d", ival),
+                                                                NULL);
+                               }
+               }
+
+       sql = g_strdup_printf ("SELECT c.id, c.nome"
+                              " FROM province AS c"
+                              " WHERE c.status <> 'E'"
+                              "%s"
+                              " ORDER BY c.nome",
+                              sql_where);
+
+    dm = gdaex_query (priv->commons->gdaex, sql);
        if (dm != NULL)
                {
                        rows = gda_data_model_get_n_rows (dm);
@@ -261,7 +301,7 @@ territorio_province_modifica (TerritorioProvince *territorio_province)
                                                                    GTK_DIALOG_DESTROY_WITH_PARENT,
                                                                    GTK_MESSAGE_WARNING,
                                                                    GTK_BUTTONS_OK,
-                                                                   "Occorre prima selezionare una provincia");
+                                                                   "Occorre prima selezionare una provincia.");
                        gtk_dialog_run (GTK_DIALOG (dialog));
                        gtk_widget_destroy (dialog);
                }
@@ -293,7 +333,7 @@ territorio_province_selezionato (TerritorioProvince *territorio_province)
                                                         GTK_DIALOG_DESTROY_WITH_PARENT,
                                                         GTK_MESSAGE_WARNING,
                                                         GTK_BUTTONS_OK,
-                                                        "Occorre prima selezionare una provincia");
+                                                        "Occorre prima selezionare una provincia.");
                        gtk_dialog_run (GTK_DIALOG (dialog));
                        gtk_widget_destroy (dialog);
                }
@@ -305,6 +345,17 @@ territorio_province_on_provincia_aggiornato (gpointer instance, gpointer user_da
        territorio_province_carica ((TerritorioProvince *)user_data);
 }
 
+static void
+territorio_province_on_filtra (gpointer instance, gpointer parametri, gpointer user_data)
+{
+       TerritorioProvince *i = (TerritorioProvince *)user_data;
+       TerritorioProvincePrivate *priv = TERRITORIO_PROVINCE_GET_PRIVATE (i);
+
+       priv->parametri_ricerca = (GHashTable *)parametri;
+
+       territorio_province_carica (i);
+}
+
 static void
 territorio_province_set_property (GObject *object, guint property_id, const GValue *value, GParamSpec *pspec)
 {
@@ -402,7 +453,7 @@ territorio_province_on_btn_elimina_clicked (GtkButton *button,
                                                         GTK_DIALOG_DESTROY_WITH_PARENT,
                                                         GTK_MESSAGE_WARNING,
                                                         GTK_BUTTONS_OK,
-                                                        "Occorre prima selezionare una provincia");
+                                                        "Occorre prima selezionare una provincia.");
                        gtk_dialog_run (GTK_DIALOG (dialog));
                        gtk_widget_destroy (dialog);
                }
@@ -426,6 +477,23 @@ territorio_province_on_trv_territorio_province_row_activated (GtkTreeView *tree_
                }
 }
 
+static void
+territorio_province_on_btn_trova_clicked (GtkButton *button,
+                        gpointer user_data)
+{
+       GtkWidget *w;
+
+       TerritorioProvincePrivate *priv = TERRITORIO_PROVINCE_GET_PRIVATE ((TerritorioProvince *)user_data);
+
+       TerritorioRicercaProvince *rf = territorio_ricerca_province_new (priv->commons, priv->parametri_ricerca);
+
+       g_signal_connect (G_OBJECT (rf), "filtra",
+                         G_CALLBACK (territorio_province_on_filtra), (TerritorioProvince *)user_data);
+
+       w = territorio_ricerca_province_get_widget (rf);
+       gtk_window_set_transient_for (GTK_WINDOW (w), priv->wtransient);
+       gtk_widget_show (w);
+}
 
 static void
 territorio_province_on_btn_annulla_clicked (GtkButton *button,
diff --git a/src/ricercacomuni.c b/src/ricercacomuni.c
new file mode 100644 (file)
index 0000000..efe1bc7
--- /dev/null
@@ -0,0 +1,257 @@
+/* 
+ * Copyright (C) 2010 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
+ *
+ */
+
+#include <libgtkform/form.h>
+
+#include "ricercacomuni.h"
+#include "province.h"
+
+static void territorio_ricerca_comuni_class_init (TerritorioRicercaComuniClass *klass);
+static void territorio_ricerca_comuni_init (TerritorioRicercaComuni *territorio_ricerca_comuni);
+
+static void territorio_ricerca_comuni_set_property (GObject *object,
+                                     guint property_id,
+                                     const GValue *value,
+                                     GParamSpec *pspec);
+static void territorio_ricerca_comuni_get_property (GObject *object,
+                                     guint property_id,
+                                     GValue *value,
+                                     GParamSpec *pspec);
+
+static void territorio_ricerca_comuni_on_provincia_selezionato (gpointer instance, guint id, gpointer user_data);
+
+static void territorio_ricerca_comuni_on_btn_provincia_clicked (GtkButton *button,
+                      gpointer user_data);
+
+static void territorio_ricerca_comuni_on_btn_pulisci_clicked (GtkButton *button,
+                      gpointer user_data);
+static void territorio_ricerca_comuni_on_btn_annulla_clicked (GtkButton *button,
+                      gpointer user_data);
+static void territorio_ricerca_comuni_on_btn_ok_clicked (GtkButton *button,
+                      gpointer user_data);
+
+#define TERRITORIO_RICERCA_COMUNI_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), TYPE_TERRITORIO_RICERCA_COMUNI, TerritorioRicercaComuniPrivate))
+
+typedef struct _TerritorioRicercaComuniPrivate TerritorioRicercaComuniPrivate;
+struct _TerritorioRicercaComuniPrivate
+       {
+               TerritorioCommons *commons;
+
+               GtkForm *form;
+
+               GtkWidget *w;
+
+               GObject **objects;
+       };
+
+G_DEFINE_TYPE (TerritorioRicercaComuni, territorio_ricerca_comuni, G_TYPE_OBJECT)
+
+static void
+territorio_ricerca_comuni_class_init (TerritorioRicercaComuniClass *klass)
+{
+       GObjectClass *object_class = G_OBJECT_CLASS (klass);
+
+       g_type_class_add_private (object_class, sizeof (TerritorioRicercaComuniPrivate));
+
+       object_class->set_property = territorio_ricerca_comuni_set_property;
+       object_class->get_property = territorio_ricerca_comuni_get_property;
+
+       /**
+        * TerritorioRicercaComuni::filtra:
+        */
+       klass->filtra_signal_id = g_signal_new ("filtra",
+                                               G_TYPE_FROM_CLASS (object_class),
+                                               G_SIGNAL_RUN_LAST,
+                                               0,
+                                               NULL,
+                                               NULL,
+                                               g_cclosure_marshal_VOID__POINTER,
+                                               G_TYPE_NONE,
+                                               1, G_TYPE_POINTER);
+}
+
+static void
+territorio_ricerca_comuni_init (TerritorioRicercaComuni *territorio_ricerca_comuni)
+{
+       TerritorioRicercaComuniPrivate *priv = TERRITORIO_RICERCA_COMUNI_GET_PRIVATE (territorio_ricerca_comuni);
+}
+
+/**
+ * territorio_ricerca_comuni_new:
+ * @commons:
+ * @values:
+ *
+ * Returns: the newly created #TerritorioRicercaComuni object.
+ */
+TerritorioRicercaComuni
+*territorio_ricerca_comuni_new (TerritorioCommons *commons, GHashTable *values)
+{
+       GError *error;
+
+       TerritorioRicercaComuni *a = TERRITORIO_RICERCA_COMUNI (g_object_new (territorio_ricerca_comuni_get_type (), NULL));
+
+       TerritorioRicercaComuniPrivate *priv = TERRITORIO_RICERCA_COMUNI_GET_PRIVATE (a);
+
+       priv->commons = commons;
+
+       error = NULL;
+       gtk_builder_add_objects_from_file (priv->commons->gtkbuilder, priv->commons->guifile,
+                                          g_strsplit ("w_ricerca_comuni", "|", -1),
+                                          &error);
+       if (error != NULL)
+               {
+                       g_warning ("Errore: %s.", 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, "ricerca_comuni.form", NULL), priv->commons->gtkbuilder);
+
+       priv->objects = gtk_form_get_objects_by_name (priv->form,
+                                                     NULL);
+
+       priv->w = GTK_WIDGET (gtk_builder_get_object (priv->commons->gtkbuilder, "w_ricerca_comuni"));
+
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button54"),
+                         "clicked", G_CALLBACK (territorio_ricerca_comuni_on_btn_provincia_clicked), (gpointer *)a);
+
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button55"),
+                         "clicked", G_CALLBACK (territorio_ricerca_comuni_on_btn_pulisci_clicked), (gpointer *)a);
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button56"),
+                         "clicked", G_CALLBACK (territorio_ricerca_comuni_on_btn_annulla_clicked), (gpointer *)a);
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button57"),
+                         "clicked", G_CALLBACK (territorio_ricerca_comuni_on_btn_ok_clicked), (gpointer *)a);
+
+       gtk_form_clear (priv->form);
+       if (values != NULL)
+               {
+                       gtk_form_fill_from_hashtable (priv->form, values);
+               }
+
+       return a;
+}
+
+/**
+ * territorio_ricerca_comuni_get_widget:
+ * @territorio_ricerca_comuni:
+ *
+ */
+GtkWidget
+*territorio_ricerca_comuni_get_widget (TerritorioRicercaComuni *territorio_ricerca_comuni)
+{
+       TerritorioRicercaComuniPrivate *priv = TERRITORIO_RICERCA_COMUNI_GET_PRIVATE (territorio_ricerca_comuni);
+
+       return priv->w;
+}
+
+/* PRIVATE */
+static void
+territorio_ricerca_comuni_set_property (GObject *object, guint property_id, const GValue *value, GParamSpec *pspec)
+{
+       TerritorioRicercaComuni *territorio_ricerca_comuni = TERRITORIO_RICERCA_COMUNI (object);
+
+       TerritorioRicercaComuniPrivate *priv = TERRITORIO_RICERCA_COMUNI_GET_PRIVATE (territorio_ricerca_comuni);
+
+       switch (property_id)
+               {
+                       default:
+                               G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+                               break;
+               }
+}
+
+static void
+territorio_ricerca_comuni_get_property (GObject *object, guint property_id, GValue *value, GParamSpec *pspec)
+{
+       TerritorioRicercaComuni *territorio_ricerca_comuni = TERRITORIO_RICERCA_COMUNI (object);
+
+       TerritorioRicercaComuniPrivate *priv = TERRITORIO_RICERCA_COMUNI_GET_PRIVATE (territorio_ricerca_comuni);
+
+       switch (property_id)
+               {
+                       default:
+                               G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+                               break;
+               }
+}
+
+/* CALLBACK */
+static void
+territorio_ricerca_comuni_on_regione_selezionato (gpointer instance, guint id, gpointer user_data)
+{
+       TerritorioRicercaComuni *f = (TerritorioRicercaComuni *)user_data;
+       TerritorioRicercaComuniPrivate *priv = TERRITORIO_RICERCA_COMUNI_GET_PRIVATE (f);
+
+       gtk_form_widget_set_value_stringify (gtk_form_get_form_widget_from_name (priv->form, "label48"), g_strdup_printf ("%d", id));
+}
+
+static void
+territorio_ricerca_comuni_on_btn_provincia_clicked (GtkButton *button,
+                      gpointer user_data)
+{
+       GtkWidget *w;
+
+       TerritorioRicercaComuni *rf = (TerritorioRicercaComuni *)user_data;
+
+       TerritorioRicercaComuniPrivate *priv = TERRITORIO_RICERCA_COMUNI_GET_PRIVATE (rf);
+
+       TerritorioProvince *c = territorio_province_new (priv->commons, TRUE);
+
+       g_signal_connect (G_OBJECT (c), "selezionato",
+                         G_CALLBACK (territorio_ricerca_comuni_on_regione_selezionato), user_data);
+
+       w = territorio_province_get_widget (c);
+       gtk_window_set_transient_for (GTK_WINDOW (w), GTK_WINDOW (priv->w));
+       gtk_widget_show (w);
+}
+
+static void
+territorio_ricerca_comuni_on_btn_pulisci_clicked (GtkButton *button,
+                      gpointer user_data)
+{
+       TerritorioRicercaComuniPrivate *priv = TERRITORIO_RICERCA_COMUNI_GET_PRIVATE ((TerritorioRicercaComuni *)user_data);
+
+       gtk_form_clear (priv->form);
+}
+
+static void
+territorio_ricerca_comuni_on_btn_annulla_clicked (GtkButton *button,
+                      gpointer user_data)
+{
+       TerritorioRicercaComuniPrivate *priv = TERRITORIO_RICERCA_COMUNI_GET_PRIVATE ((TerritorioRicercaComuni *)user_data);
+
+       gtk_widget_destroy (priv->w);
+       g_object_unref (user_data);
+}
+
+static void
+territorio_ricerca_comuni_on_btn_ok_clicked (GtkButton *button,
+                      gpointer user_data)
+{
+       TerritorioRicercaComuni *territorio_ricerca_comuni = (TerritorioRicercaComuni *)user_data;
+       TerritorioRicercaComuniClass *klass = TERRITORIO_RICERCA_COMUNI_GET_CLASS (territorio_ricerca_comuni);
+
+       TerritorioRicercaComuniPrivate *priv = TERRITORIO_RICERCA_COMUNI_GET_PRIVATE (territorio_ricerca_comuni);
+
+       g_signal_emit (territorio_ricerca_comuni, klass->filtra_signal_id, 0, gtk_form_get_values_as_hashtable (priv->form));
+
+       gtk_widget_destroy (priv->w);
+       g_object_unref (user_data);
+}
diff --git a/src/ricercacomuni.h b/src/ricercacomuni.h
new file mode 100644 (file)
index 0000000..484078b
--- /dev/null
@@ -0,0 +1,66 @@
+/* 
+ * Copyright (C) 2010 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 __TERRITORIO_RICERCA_COMUNI_H__
+#define __TERRITORIO_RICERCA_COMUNI_H__
+
+#include <glib.h>
+#include <glib-object.h>
+
+#include <gtk/gtk.h>
+#include <libgdaex.h>
+
+#include "commons.h"
+
+G_BEGIN_DECLS
+
+
+#define TYPE_TERRITORIO_RICERCA_COMUNI                 (territorio_ricerca_comuni_get_type ())
+#define TERRITORIO_RICERCA_COMUNI(obj)                 (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_TERRITORIO_RICERCA_COMUNI, TerritorioRicercaComuni))
+#define TERRITORIO_RICERCA_COMUNI_CLASS(klass)         (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_TERRITORIO_RICERCA_COMUNI, TerritorioRicercaComuniClass))
+#define IS_TERRITORIO_RICERCA_COMUNI(obj)              (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_TERRITORIO_RICERCA_COMUNI))
+#define IS_TERRITORIO_RICERCA_COMUNI_CLASS(klass)      (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_TERRITORIO_RICERCA_COMUNI))
+#define TERRITORIO_RICERCA_COMUNI_GET_CLASS(obj)       (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_TERRITORIO_RICERCA_COMUNI, TerritorioRicercaComuniClass))
+
+
+typedef struct _TerritorioRicercaComuni TerritorioRicercaComuni;
+typedef struct _TerritorioRicercaComuniClass TerritorioRicercaComuniClass;
+
+struct _TerritorioRicercaComuni
+       {
+               GObject parent;
+       };
+
+struct _TerritorioRicercaComuniClass
+       {
+               GObjectClass parent_class;
+
+               guint filtra_signal_id;
+       };
+
+GType territorio_ricerca_comuni_get_type (void) G_GNUC_CONST;
+
+TerritorioRicercaComuni *territorio_ricerca_comuni_new (TerritorioCommons *commons, GHashTable *values);
+
+GtkWidget *territorio_ricerca_comuni_get_widget (TerritorioRicercaComuni *territorio_ricerca_comuni);
+
+
+G_END_DECLS
+
+#endif /* __TERRITORIO_RICERCA_COMUNI_H__ */
diff --git a/src/ricercaprovince.c b/src/ricercaprovince.c
new file mode 100644 (file)
index 0000000..6c97e49
--- /dev/null
@@ -0,0 +1,257 @@
+/* 
+ * Copyright (C) 2010 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
+ *
+ */
+
+#include <libgtkform/form.h>
+
+#include "ricercaprovince.h"
+#include "regioni.h"
+
+static void territorio_ricerca_province_class_init (TerritorioRicercaProvinceClass *klass);
+static void territorio_ricerca_province_init (TerritorioRicercaProvince *territorio_ricerca_province);
+
+static void territorio_ricerca_province_set_property (GObject *object,
+                                     guint property_id,
+                                     const GValue *value,
+                                     GParamSpec *pspec);
+static void territorio_ricerca_province_get_property (GObject *object,
+                                     guint property_id,
+                                     GValue *value,
+                                     GParamSpec *pspec);
+
+static void territorio_ricerca_province_on_regione_selezionato (gpointer instance, guint id, gpointer user_data);
+
+static void territorio_ricerca_province_on_btn_regione_clicked (GtkButton *button,
+                      gpointer user_data);
+
+static void territorio_ricerca_province_on_btn_pulisci_clicked (GtkButton *button,
+                      gpointer user_data);
+static void territorio_ricerca_province_on_btn_annulla_clicked (GtkButton *button,
+                      gpointer user_data);
+static void territorio_ricerca_province_on_btn_ok_clicked (GtkButton *button,
+                      gpointer user_data);
+
+#define TERRITORIO_RICERCA_PROVINCE_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), TYPE_TERRITORIO_RICERCA_PROVINCE, TerritorioRicercaProvincePrivate))
+
+typedef struct _TerritorioRicercaProvincePrivate TerritorioRicercaProvincePrivate;
+struct _TerritorioRicercaProvincePrivate
+       {
+               TerritorioCommons *commons;
+
+               GtkForm *form;
+
+               GtkWidget *w;
+
+               GObject **objects;
+       };
+
+G_DEFINE_TYPE (TerritorioRicercaProvince, territorio_ricerca_province, G_TYPE_OBJECT)
+
+static void
+territorio_ricerca_province_class_init (TerritorioRicercaProvinceClass *klass)
+{
+       GObjectClass *object_class = G_OBJECT_CLASS (klass);
+
+       g_type_class_add_private (object_class, sizeof (TerritorioRicercaProvincePrivate));
+
+       object_class->set_property = territorio_ricerca_province_set_property;
+       object_class->get_property = territorio_ricerca_province_get_property;
+
+       /**
+        * TerritorioRicercaProvince::filtra:
+        */
+       klass->filtra_signal_id = g_signal_new ("filtra",
+                                               G_TYPE_FROM_CLASS (object_class),
+                                               G_SIGNAL_RUN_LAST,
+                                               0,
+                                               NULL,
+                                               NULL,
+                                               g_cclosure_marshal_VOID__POINTER,
+                                               G_TYPE_NONE,
+                                               1, G_TYPE_POINTER);
+}
+
+static void
+territorio_ricerca_province_init (TerritorioRicercaProvince *territorio_ricerca_province)
+{
+       TerritorioRicercaProvincePrivate *priv = TERRITORIO_RICERCA_PROVINCE_GET_PRIVATE (territorio_ricerca_province);
+}
+
+/**
+ * territorio_ricerca_province_new:
+ * @commons:
+ * @values:
+ *
+ * Returns: the newly created #TerritorioRicercaProvince object.
+ */
+TerritorioRicercaProvince
+*territorio_ricerca_province_new (TerritorioCommons *commons, GHashTable *values)
+{
+       GError *error;
+
+       TerritorioRicercaProvince *a = TERRITORIO_RICERCA_PROVINCE (g_object_new (territorio_ricerca_province_get_type (), NULL));
+
+       TerritorioRicercaProvincePrivate *priv = TERRITORIO_RICERCA_PROVINCE_GET_PRIVATE (a);
+
+       priv->commons = commons;
+
+       error = NULL;
+       gtk_builder_add_objects_from_file (priv->commons->gtkbuilder, priv->commons->guifile,
+                                          g_strsplit ("w_ricerca_province", "|", -1),
+                                          &error);
+       if (error != NULL)
+               {
+                       g_warning ("Errore: %s.", 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, "ricerca_province.form", NULL), priv->commons->gtkbuilder);
+
+       priv->objects = gtk_form_get_objects_by_name (priv->form,
+                                                     NULL);
+
+       priv->w = GTK_WIDGET (gtk_builder_get_object (priv->commons->gtkbuilder, "w_ricerca_province"));
+
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button69"),
+                         "clicked", G_CALLBACK (territorio_ricerca_province_on_btn_regione_clicked), (gpointer *)a);
+
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button70"),
+                         "clicked", G_CALLBACK (territorio_ricerca_province_on_btn_pulisci_clicked), (gpointer *)a);
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button67"),
+                         "clicked", G_CALLBACK (territorio_ricerca_province_on_btn_annulla_clicked), (gpointer *)a);
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button68"),
+                         "clicked", G_CALLBACK (territorio_ricerca_province_on_btn_ok_clicked), (gpointer *)a);
+
+       gtk_form_clear (priv->form);
+       if (values != NULL)
+               {
+                       gtk_form_fill_from_hashtable (priv->form, values);
+               }
+
+       return a;
+}
+
+/**
+ * territorio_ricerca_province_get_widget:
+ * @territorio_ricerca_province:
+ *
+ */
+GtkWidget
+*territorio_ricerca_province_get_widget (TerritorioRicercaProvince *territorio_ricerca_province)
+{
+       TerritorioRicercaProvincePrivate *priv = TERRITORIO_RICERCA_PROVINCE_GET_PRIVATE (territorio_ricerca_province);
+
+       return priv->w;
+}
+
+/* PRIVATE */
+static void
+territorio_ricerca_province_set_property (GObject *object, guint property_id, const GValue *value, GParamSpec *pspec)
+{
+       TerritorioRicercaProvince *territorio_ricerca_province = TERRITORIO_RICERCA_PROVINCE (object);
+
+       TerritorioRicercaProvincePrivate *priv = TERRITORIO_RICERCA_PROVINCE_GET_PRIVATE (territorio_ricerca_province);
+
+       switch (property_id)
+               {
+                       default:
+                               G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+                               break;
+               }
+}
+
+static void
+territorio_ricerca_province_get_property (GObject *object, guint property_id, GValue *value, GParamSpec *pspec)
+{
+       TerritorioRicercaProvince *territorio_ricerca_province = TERRITORIO_RICERCA_PROVINCE (object);
+
+       TerritorioRicercaProvincePrivate *priv = TERRITORIO_RICERCA_PROVINCE_GET_PRIVATE (territorio_ricerca_province);
+
+       switch (property_id)
+               {
+                       default:
+                               G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+                               break;
+               }
+}
+
+/* CALLBACK */
+static void
+territorio_ricerca_province_on_regione_selezionato (gpointer instance, guint id, gpointer user_data)
+{
+       TerritorioRicercaProvince *f = (TerritorioRicercaProvince *)user_data;
+       TerritorioRicercaProvincePrivate *priv = TERRITORIO_RICERCA_PROVINCE_GET_PRIVATE (f);
+
+       gtk_form_widget_set_value_stringify (gtk_form_get_form_widget_from_name (priv->form, "label60"), g_strdup_printf ("%d", id));
+}
+
+static void
+territorio_ricerca_province_on_btn_regione_clicked (GtkButton *button,
+                      gpointer user_data)
+{
+       GtkWidget *w;
+
+       TerritorioRicercaProvince *rf = (TerritorioRicercaProvince *)user_data;
+
+       TerritorioRicercaProvincePrivate *priv = TERRITORIO_RICERCA_PROVINCE_GET_PRIVATE (rf);
+
+       TerritorioRegioni *c = territorio_regioni_new (priv->commons, TRUE);
+
+       g_signal_connect (G_OBJECT (c), "selezionato",
+                         G_CALLBACK (territorio_ricerca_province_on_regione_selezionato), user_data);
+
+       w = territorio_regioni_get_widget (c);
+       gtk_window_set_transient_for (GTK_WINDOW (w), GTK_WINDOW (priv->w));
+       gtk_widget_show (w);
+}
+
+static void
+territorio_ricerca_province_on_btn_pulisci_clicked (GtkButton *button,
+                      gpointer user_data)
+{
+       TerritorioRicercaProvincePrivate *priv = TERRITORIO_RICERCA_PROVINCE_GET_PRIVATE ((TerritorioRicercaProvince *)user_data);
+
+       gtk_form_clear (priv->form);
+}
+
+static void
+territorio_ricerca_province_on_btn_annulla_clicked (GtkButton *button,
+                      gpointer user_data)
+{
+       TerritorioRicercaProvincePrivate *priv = TERRITORIO_RICERCA_PROVINCE_GET_PRIVATE ((TerritorioRicercaProvince *)user_data);
+
+       gtk_widget_destroy (priv->w);
+       g_object_unref (user_data);
+}
+
+static void
+territorio_ricerca_province_on_btn_ok_clicked (GtkButton *button,
+                      gpointer user_data)
+{
+       TerritorioRicercaProvince *territorio_ricerca_province = (TerritorioRicercaProvince *)user_data;
+       TerritorioRicercaProvinceClass *klass = TERRITORIO_RICERCA_PROVINCE_GET_CLASS (territorio_ricerca_province);
+
+       TerritorioRicercaProvincePrivate *priv = TERRITORIO_RICERCA_PROVINCE_GET_PRIVATE (territorio_ricerca_province);
+
+       g_signal_emit (territorio_ricerca_province, klass->filtra_signal_id, 0, gtk_form_get_values_as_hashtable (priv->form));
+
+       gtk_widget_destroy (priv->w);
+       g_object_unref (user_data);
+}
diff --git a/src/ricercaprovince.h b/src/ricercaprovince.h
new file mode 100644 (file)
index 0000000..a2d0689
--- /dev/null
@@ -0,0 +1,66 @@
+/* 
+ * Copyright (C) 2010 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 __TERRITORIO_RICERCA_PROVINCE_H__
+#define __TERRITORIO_RICERCA_PROVINCE_H__
+
+#include <glib.h>
+#include <glib-object.h>
+
+#include <gtk/gtk.h>
+#include <libgdaex.h>
+
+#include "commons.h"
+
+G_BEGIN_DECLS
+
+
+#define TYPE_TERRITORIO_RICERCA_PROVINCE                 (territorio_ricerca_province_get_type ())
+#define TERRITORIO_RICERCA_PROVINCE(obj)                 (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_TERRITORIO_RICERCA_PROVINCE, TerritorioRicercaProvince))
+#define TERRITORIO_RICERCA_PROVINCE_CLASS(klass)         (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_TERRITORIO_RICERCA_PROVINCE, TerritorioRicercaProvinceClass))
+#define IS_TERRITORIO_RICERCA_PROVINCE(obj)              (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_TERRITORIO_RICERCA_PROVINCE))
+#define IS_TERRITORIO_RICERCA_PROVINCE_CLASS(klass)      (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_TERRITORIO_RICERCA_PROVINCE))
+#define TERRITORIO_RICERCA_PROVINCE_GET_CLASS(obj)       (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_TERRITORIO_RICERCA_PROVINCE, TerritorioRicercaProvinceClass))
+
+
+typedef struct _TerritorioRicercaProvince TerritorioRicercaProvince;
+typedef struct _TerritorioRicercaProvinceClass TerritorioRicercaProvinceClass;
+
+struct _TerritorioRicercaProvince
+       {
+               GObject parent;
+       };
+
+struct _TerritorioRicercaProvinceClass
+       {
+               GObjectClass parent_class;
+
+               guint filtra_signal_id;
+       };
+
+GType territorio_ricerca_province_get_type (void) G_GNUC_CONST;
+
+TerritorioRicercaProvince *territorio_ricerca_province_new (TerritorioCommons *commons, GHashTable *values);
+
+GtkWidget *territorio_ricerca_province_get_widget (TerritorioRicercaProvince *territorio_ricerca_province);
+
+
+G_END_DECLS
+
+#endif /* __TERRITORIO_RICERCA_PROVINCE_H__ */
diff --git a/src/ricercavie.c b/src/ricercavie.c
new file mode 100644 (file)
index 0000000..fc1975d
--- /dev/null
@@ -0,0 +1,257 @@
+/* 
+ * Copyright (C) 2010 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
+ *
+ */
+
+#include <libgtkform/form.h>
+
+#include "ricercavie.h"
+#include "comuni.h"
+
+static void territorio_ricerca_vie_class_init (TerritorioRicercaVieClass *klass);
+static void territorio_ricerca_vie_init (TerritorioRicercaVie *territorio_ricerca_vie);
+
+static void territorio_ricerca_vie_set_property (GObject *object,
+                                     guint property_id,
+                                     const GValue *value,
+                                     GParamSpec *pspec);
+static void territorio_ricerca_vie_get_property (GObject *object,
+                                     guint property_id,
+                                     GValue *value,
+                                     GParamSpec *pspec);
+
+static void territorio_ricerca_vie_on_comune_selezionato (gpointer instance, guint id, gpointer user_data);
+
+static void territorio_ricerca_vie_on_btn_comune_clicked (GtkButton *button,
+                      gpointer user_data);
+
+static void territorio_ricerca_vie_on_btn_pulisci_clicked (GtkButton *button,
+                      gpointer user_data);
+static void territorio_ricerca_vie_on_btn_annulla_clicked (GtkButton *button,
+                      gpointer user_data);
+static void territorio_ricerca_vie_on_btn_ok_clicked (GtkButton *button,
+                      gpointer user_data);
+
+#define TERRITORIO_RICERCA_VIE_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), TYPE_TERRITORIO_RICERCA_VIE, TerritorioRicercaViePrivate))
+
+typedef struct _TerritorioRicercaViePrivate TerritorioRicercaViePrivate;
+struct _TerritorioRicercaViePrivate
+       {
+               TerritorioCommons *commons;
+
+               GtkForm *form;
+
+               GtkWidget *w;
+
+               GObject **objects;
+       };
+
+G_DEFINE_TYPE (TerritorioRicercaVie, territorio_ricerca_vie, G_TYPE_OBJECT)
+
+static void
+territorio_ricerca_vie_class_init (TerritorioRicercaVieClass *klass)
+{
+       GObjectClass *object_class = G_OBJECT_CLASS (klass);
+
+       g_type_class_add_private (object_class, sizeof (TerritorioRicercaViePrivate));
+
+       object_class->set_property = territorio_ricerca_vie_set_property;
+       object_class->get_property = territorio_ricerca_vie_get_property;
+
+       /**
+        * TerritorioRicercaVie::filtra:
+        */
+       klass->filtra_signal_id = g_signal_new ("filtra",
+                                               G_TYPE_FROM_CLASS (object_class),
+                                               G_SIGNAL_RUN_LAST,
+                                               0,
+                                               NULL,
+                                               NULL,
+                                               g_cclosure_marshal_VOID__POINTER,
+                                               G_TYPE_NONE,
+                                               1, G_TYPE_POINTER);
+}
+
+static void
+territorio_ricerca_vie_init (TerritorioRicercaVie *territorio_ricerca_vie)
+{
+       TerritorioRicercaViePrivate *priv = TERRITORIO_RICERCA_VIE_GET_PRIVATE (territorio_ricerca_vie);
+}
+
+/**
+ * territorio_ricerca_vie_new:
+ * @commons:
+ * @values:
+ *
+ * Returns: the newly created #TerritorioRicercaVie object.
+ */
+TerritorioRicercaVie
+*territorio_ricerca_vie_new (TerritorioCommons *commons, GHashTable *values)
+{
+       GError *error;
+
+       TerritorioRicercaVie *a = TERRITORIO_RICERCA_VIE (g_object_new (territorio_ricerca_vie_get_type (), NULL));
+
+       TerritorioRicercaViePrivate *priv = TERRITORIO_RICERCA_VIE_GET_PRIVATE (a);
+
+       priv->commons = commons;
+
+       error = NULL;
+       gtk_builder_add_objects_from_file (priv->commons->gtkbuilder, priv->commons->guifile,
+                                          g_strsplit ("w_ricerca_vie", "|", -1),
+                                          &error);
+       if (error != NULL)
+               {
+                       g_warning ("Errore: %s.", 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, "ricerca_vie.form", NULL), priv->commons->gtkbuilder);
+
+       priv->objects = gtk_form_get_objects_by_name (priv->form,
+                                                     NULL);
+
+       priv->w = GTK_WIDGET (gtk_builder_get_object (priv->commons->gtkbuilder, "w_ricerca_vie"));
+
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button59"),
+                         "clicked", G_CALLBACK (territorio_ricerca_vie_on_btn_comune_clicked), (gpointer *)a);
+
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button60"),
+                         "clicked", G_CALLBACK (territorio_ricerca_vie_on_btn_pulisci_clicked), (gpointer *)a);
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button61"),
+                         "clicked", G_CALLBACK (territorio_ricerca_vie_on_btn_annulla_clicked), (gpointer *)a);
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button62"),
+                         "clicked", G_CALLBACK (territorio_ricerca_vie_on_btn_ok_clicked), (gpointer *)a);
+
+       gtk_form_clear (priv->form);
+       if (values != NULL)
+               {
+                       gtk_form_fill_from_hashtable (priv->form, values);
+               }
+
+       return a;
+}
+
+/**
+ * territorio_ricerca_vie_get_widget:
+ * @territorio_ricerca_vie:
+ *
+ */
+GtkWidget
+*territorio_ricerca_vie_get_widget (TerritorioRicercaVie *territorio_ricerca_vie)
+{
+       TerritorioRicercaViePrivate *priv = TERRITORIO_RICERCA_VIE_GET_PRIVATE (territorio_ricerca_vie);
+
+       return priv->w;
+}
+
+/* PRIVATE */
+static void
+territorio_ricerca_vie_set_property (GObject *object, guint property_id, const GValue *value, GParamSpec *pspec)
+{
+       TerritorioRicercaVie *territorio_ricerca_vie = TERRITORIO_RICERCA_VIE (object);
+
+       TerritorioRicercaViePrivate *priv = TERRITORIO_RICERCA_VIE_GET_PRIVATE (territorio_ricerca_vie);
+
+       switch (property_id)
+               {
+                       default:
+                               G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+                               break;
+               }
+}
+
+static void
+territorio_ricerca_vie_get_property (GObject *object, guint property_id, GValue *value, GParamSpec *pspec)
+{
+       TerritorioRicercaVie *territorio_ricerca_vie = TERRITORIO_RICERCA_VIE (object);
+
+       TerritorioRicercaViePrivate *priv = TERRITORIO_RICERCA_VIE_GET_PRIVATE (territorio_ricerca_vie);
+
+       switch (property_id)
+               {
+                       default:
+                               G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+                               break;
+               }
+}
+
+/* CALLBACK */
+static void
+territorio_ricerca_vie_on_comune_selezionato (gpointer instance, guint id, gpointer user_data)
+{
+       TerritorioRicercaVie *f = (TerritorioRicercaVie *)user_data;
+       TerritorioRicercaViePrivate *priv = TERRITORIO_RICERCA_VIE_GET_PRIVATE (f);
+
+       gtk_form_widget_set_value_stringify (gtk_form_get_form_widget_from_name (priv->form, "label51"), g_strdup_printf ("%d", id));
+}
+
+static void
+territorio_ricerca_vie_on_btn_comune_clicked (GtkButton *button,
+                      gpointer user_data)
+{
+       GtkWidget *w;
+
+       TerritorioRicercaVie *rf = (TerritorioRicercaVie *)user_data;
+
+       TerritorioRicercaViePrivate *priv = TERRITORIO_RICERCA_VIE_GET_PRIVATE (rf);
+
+       TerritorioComuni *c = territorio_comuni_new (priv->commons, TRUE);
+
+       g_signal_connect (G_OBJECT (c), "selezionato",
+                         G_CALLBACK (territorio_ricerca_vie_on_comune_selezionato), user_data);
+
+       w = territorio_comuni_get_widget (c);
+       gtk_window_set_transient_for (GTK_WINDOW (w), GTK_WINDOW (priv->w));
+       gtk_widget_show (w);
+}
+
+static void
+territorio_ricerca_vie_on_btn_pulisci_clicked (GtkButton *button,
+                      gpointer user_data)
+{
+       TerritorioRicercaViePrivate *priv = TERRITORIO_RICERCA_VIE_GET_PRIVATE ((TerritorioRicercaVie *)user_data);
+
+       gtk_form_clear (priv->form);
+}
+
+static void
+territorio_ricerca_vie_on_btn_annulla_clicked (GtkButton *button,
+                      gpointer user_data)
+{
+       TerritorioRicercaViePrivate *priv = TERRITORIO_RICERCA_VIE_GET_PRIVATE ((TerritorioRicercaVie *)user_data);
+
+       gtk_widget_destroy (priv->w);
+       g_object_unref (user_data);
+}
+
+static void
+territorio_ricerca_vie_on_btn_ok_clicked (GtkButton *button,
+                      gpointer user_data)
+{
+       TerritorioRicercaVie *territorio_ricerca_vie = (TerritorioRicercaVie *)user_data;
+       TerritorioRicercaVieClass *klass = TERRITORIO_RICERCA_VIE_GET_CLASS (territorio_ricerca_vie);
+
+       TerritorioRicercaViePrivate *priv = TERRITORIO_RICERCA_VIE_GET_PRIVATE (territorio_ricerca_vie);
+
+       g_signal_emit (territorio_ricerca_vie, klass->filtra_signal_id, 0, gtk_form_get_values_as_hashtable (priv->form));
+
+       gtk_widget_destroy (priv->w);
+       g_object_unref (user_data);
+}
diff --git a/src/ricercavie.h b/src/ricercavie.h
new file mode 100644 (file)
index 0000000..5087615
--- /dev/null
@@ -0,0 +1,66 @@
+/* 
+ * Copyright (C) 2010 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 __TERRITORIO_RICERCA_VIE_H__
+#define __TERRITORIO_RICERCA_VIE_H__
+
+#include <glib.h>
+#include <glib-object.h>
+
+#include <gtk/gtk.h>
+#include <libgdaex.h>
+
+#include "commons.h"
+
+G_BEGIN_DECLS
+
+
+#define TYPE_TERRITORIO_RICERCA_VIE                 (territorio_ricerca_vie_get_type ())
+#define TERRITORIO_RICERCA_VIE(obj)                 (G_TYPE_CHECK_INSTANCE_CAST ((obj), TYPE_TERRITORIO_RICERCA_VIE, TerritorioRicercaVie))
+#define TERRITORIO_RICERCA_VIE_CLASS(klass)         (G_TYPE_CHECK_CLASS_CAST ((klass), TYPE_TERRITORIO_RICERCA_VIE, TerritorioRicercaVieClass))
+#define IS_TERRITORIO_RICERCA_VIE(obj)              (G_TYPE_CHECK_INSTANCE_TYPE ((obj), TYPE_TERRITORIO_RICERCA_VIE))
+#define IS_TERRITORIO_RICERCA_VIE_CLASS(klass)      (G_TYPE_CHECK_CLASS_TYPE ((klass), TYPE_TERRITORIO_RICERCA_VIE))
+#define TERRITORIO_RICERCA_VIE_GET_CLASS(obj)       (G_TYPE_INSTANCE_GET_CLASS ((obj), TYPE_TERRITORIO_RICERCA_VIE, TerritorioRicercaVieClass))
+
+
+typedef struct _TerritorioRicercaVie TerritorioRicercaVie;
+typedef struct _TerritorioRicercaVieClass TerritorioRicercaVieClass;
+
+struct _TerritorioRicercaVie
+       {
+               GObject parent;
+       };
+
+struct _TerritorioRicercaVieClass
+       {
+               GObjectClass parent_class;
+
+               guint filtra_signal_id;
+       };
+
+GType territorio_ricerca_vie_get_type (void) G_GNUC_CONST;
+
+TerritorioRicercaVie *territorio_ricerca_vie_new (TerritorioCommons *commons, GHashTable *values);
+
+GtkWidget *territorio_ricerca_vie_get_widget (TerritorioRicercaVie *territorio_ricerca_vie);
+
+
+G_END_DECLS
+
+#endif /* __TERRITORIO_RICERCA_VIE_H__ */
index e8faa7be01e6a8fdf045e9f817e4367647bc4bf3..f5f9c7e6f9ed540a7e08bedc2c50f64bd626730e 100644 (file)
--- a/src/vie.c
+++ b/src/vie.c
  *
  */
 
+#include <string.h>
+
 #include "vie.h"
 #include "via.h"
+#include "ricercavie.h"
 
 static void territorio_vie_class_init (TerritorioVieClass *klass);
 static void territorio_vie_init (TerritorioVie *territorio_vie);
@@ -29,6 +32,8 @@ static void territorio_vie_modifica (TerritorioVie *territorio_vie);
 static void territorio_vie_selezionato (TerritorioVie *territorio_vie);
 static void territorio_vie_on_via_aggiornato (gpointer instance, gpointer user_data);
 
+static void territorio_vie_on_filtra (gpointer instance, gpointer parametri, gpointer user_data);
+
 static void territorio_vie_set_property (GObject *object,
                                      guint property_id,
                                      const GValue *value,
@@ -49,11 +54,21 @@ static void territorio_vie_on_trv_vie_row_activated (GtkTreeView *tree_view,
                                              GtkTreeViewColumn *column,
                                              gpointer user_data);
 
+static void territorio_vie_on_btn_trova_clicked (GtkButton *button,
+                                    gpointer user_data);
+
 static void territorio_vie_on_btn_annulla_clicked (GtkButton *button,
                                     gpointer user_data);
 static void territorio_vie_on_btn_seleziona_clicked (GtkButton *button,
                                   gpointer user_data);
 
+static gboolean search_func (GtkTreeModel *model,
+                             gint column,
+                             const gchar *key,
+                             GtkTreeIter *iter,
+                             gpointer search_data);
+
+
 #define TERRITORIO_VIE_GET_PRIVATE(obj) (G_TYPE_INSTANCE_GET_PRIVATE ((obj), TYPE_TERRITORIO_VIE, TerritorioViePrivate))
 
 enum
@@ -71,6 +86,8 @@ struct _TerritorioViePrivate
                GtkTreeSelection *selection;
                GtkListStore *lstore_vie;
 
+               GHashTable *parametri_ricerca;
+
                gboolean selezione;
                GtkWindow *wtransient;
        };
@@ -144,6 +161,8 @@ TerritorioVie
        priv->selection = gtk_tree_view_get_selection (GTK_TREE_VIEW (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview7")));
        priv->lstore_vie = GTK_LIST_STORE (gtk_builder_get_object (priv->commons->gtkbuilder, "lstore_vie"));
 
+       gtk_tree_view_set_search_equal_func (GTK_TREE_VIEW (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview7")), search_func, NULL, NULL);
+
        if (priv->selezione)
                {
                        priv->wtransient = GTK_WINDOW (priv->widget);
@@ -161,6 +180,8 @@ TerritorioVie
                          "clicked", G_CALLBACK (territorio_vie_on_btn_elimina_clicked), (gpointer)a);
        g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "treeview7"),
                          "row-activated", G_CALLBACK (territorio_vie_on_trv_vie_row_activated), (gpointer)a);
+       g_signal_connect (gtk_builder_get_object (priv->commons->gtkbuilder, "button63"),
+                         "clicked", G_CALLBACK (territorio_vie_on_btn_trova_clicked), (gpointer)a);
 
        if (priv->selezione)
                {
@@ -201,6 +222,13 @@ territorio_vie_carica (TerritorioVie *territorio_vie)
        GtkTreeIter iter;
        GdaDataModel *dm;
 
+       gchar *sql;
+       gchar *sql_where;
+
+       GValue *gvalue;
+       gchar *gcval;
+       gint ival;
+
        gint rows;
        gint row;
 
@@ -208,11 +236,34 @@ territorio_vie_carica (TerritorioVie *territorio_vie)
 
        gtk_list_store_clear (priv->lstore_vie);
 
-       dm = gdaex_query (priv->commons->gdaex,
-                         "SELECT c.id, c.nome"
-                         " FROM vie AS c"
-                         " WHERE c.status <> 'E'"
-                         " ORDER BY c.nome");
+       sql_where = g_strdup ("");
+       if (priv->parametri_ricerca != NULL)
+               {
+                       gcval = g_strstrip ((gchar *)g_value_get_string ((GValue *)g_hash_table_lookup (priv->parametri_ricerca, "nome")));
+                       if (g_strcmp0 (gcval, "") != 0)
+                               {
+                                       sql_where = g_strconcat (sql_where, " AND c.nome ILIKE '%",
+                                                                g_strdup_printf ("%s", gcval),
+                                                                "%'",
+                                                                NULL);
+                               }
+                       ival = g_value_get_int ((GValue *)g_hash_table_lookup (priv->parametri_ricerca, "id_comuni"));
+                       if (ival != 0)
+                               {
+                                       sql_where = g_strconcat (sql_where, " AND c.id_comuni = ",
+                                                                g_strdup_printf ("%d", ival),
+                                                                NULL);
+                               }
+               }
+
+       sql = g_strdup_printf ("SELECT c.id, c.nome"
+                              " FROM vie AS c"
+                              " WHERE c.status <> 'E'"
+                              "%s"
+                              " ORDER BY c.nome",
+                              sql_where);
+
+       dm = gdaex_query (priv->commons->gdaex, sql);
        if (dm != NULL)
                {
                        rows = gda_data_model_get_n_rows (dm);
@@ -305,6 +356,17 @@ territorio_vie_on_via_aggiornato (gpointer instance, gpointer user_data)
        territorio_vie_carica ((TerritorioVie *)user_data);
 }
 
+static void
+territorio_vie_on_filtra (gpointer instance, gpointer parametri, gpointer user_data)
+{
+       TerritorioVie *i = (TerritorioVie *)user_data;
+       TerritorioViePrivate *priv = TERRITORIO_VIE_GET_PRIVATE (i);
+
+       priv->parametri_ricerca = (GHashTable *)parametri;
+
+       territorio_vie_carica (i);
+}
+
 static void
 territorio_vie_set_property (GObject *object, guint property_id, const GValue *value, GParamSpec *pspec)
 {
@@ -427,6 +489,24 @@ territorio_vie_on_trv_vie_row_activated (GtkTreeView *tree_view,
 }
 
 
+static void
+territorio_vie_on_btn_trova_clicked (GtkButton *button,
+                        gpointer user_data)
+{
+       GtkWidget *w;
+
+       TerritorioViePrivate *priv = TERRITORIO_VIE_GET_PRIVATE ((TerritorioVie *)user_data);
+
+       TerritorioRicercaVie *rf = territorio_ricerca_vie_new (priv->commons, priv->parametri_ricerca);
+
+       g_signal_connect (G_OBJECT (rf), "filtra",
+                         G_CALLBACK (territorio_vie_on_filtra), (TerritorioVie *)user_data);
+
+       w = territorio_ricerca_vie_get_widget (rf);
+       gtk_window_set_transient_for (GTK_WINDOW (w), priv->wtransient);
+       gtk_widget_show (w);
+}
+
 static void
 territorio_vie_on_btn_annulla_clicked (GtkButton *button,
                         gpointer user_data)
@@ -443,3 +523,21 @@ territorio_vie_on_btn_seleziona_clicked (GtkButton *button,
 {
        territorio_vie_selezionato ((TerritorioVie *)user_data);
 }
+
+static gboolean
+search_func (GtkTreeModel *model,
+                             gint column,
+                             const gchar *key,
+                             GtkTreeIter *iter,
+                             gpointer search_data)
+{
+       gchar *str;
+       char *ret;
+
+       ret = NULL;
+
+       gtk_tree_model_get (model, iter, column, &str, -1);
+       ret = strstr ((const char *)g_utf8_strdown (str, -1), (const char *)g_utf8_strdown (key, -1));
+
+       return (ret == NULL);
+}