<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="model">lstore_stati</property>
+ <property name="rules_hint">True</property>
<property name="search_column">1</property>
<child>
<object class="GtkTreeViewColumn" id="treeviewcolumn2">
<property name="can_focus">True</property>
<property name="max_length">255</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="can_focus">True</property>
<property name="max_length">255</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="can_focus">True</property>
<property name="max_length">5</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="can_focus">True</property>
<property name="max_length">5</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="model">lstore_regioni</property>
+ <property name="rules_hint">True</property>
<property name="search_column">1</property>
<child>
<object class="GtkTreeViewColumn" id="treeviewcolumn1">
<property name="can_focus">True</property>
<property name="max_length">255</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="can_focus">True</property>
<property name="max_length">5</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="model">lstore_province</property>
+ <property name="rules_hint">True</property>
<property name="search_column">1</property>
<child>
<object class="GtkTreeViewColumn" id="treeviewcolumn3">
<property name="can_focus">True</property>
<property name="max_length">255</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="can_focus">True</property>
<property name="max_length">5</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="can_focus">True</property>
<property name="max_length">5</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="model">lstore_comuni</property>
+ <property name="rules_hint">True</property>
<property name="search_column">1</property>
<child>
<object class="GtkTreeViewColumn" id="treeviewcolumn4">
<property name="can_focus">True</property>
<property name="max_length">255</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="can_focus">True</property>
<property name="max_length">5</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="can_focus">True</property>
<property name="max_length">5</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="can_focus">True</property>
<property name="model">lstore_tipi_aggregazione_territoriale</property>
<property name="headers_clickable">False</property>
+ <property name="rules_hint">True</property>
<property name="search_column">0</property>
<child>
<object class="GtkTreeViewColumn" id="treeviewcolumn5">
<property name="can_focus">True</property>
<property name="max_length">150</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="can_focus">True</property>
<property name="model">lstore_aggregazioni_territoriali</property>
<property name="headers_clickable">False</property>
+ <property name="rules_hint">True</property>
<property name="search_column">0</property>
<child>
<object class="GtkTreeViewColumn" id="treeviewcolumn6">
<property name="can_focus">True</property>
<property name="max_length">150</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
<property name="text" translatable="yes">uu</property>
</object>
<packing>
<property name="can_focus">True</property>
<property name="model">lstore_vie</property>
<property name="headers_clickable">False</property>
+ <property name="rules_hint">True</property>
<property name="search_column">1</property>
<child>
<object class="GtkTreeViewColumn" id="treeviewcolumn7">
<property name="can_focus">True</property>
<property name="max_length">255</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="can_focus">True</property>
<property name="max_length">5</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
<property name="visible">True</property>
<property name="can_focus">True</property>
<property name="invisible_char">●</property>
+ <property name="activates_default">True</property>
</object>
<packing>
<property name="left_attach">1</property>
*/
#include <libgda-ui/libgda-ui.h>
+#include <libsolipa/libsolipa.h>
#include "importaviecivilia.h"
TerritorioImportaVieCivilia
*territorio_importa_viecivilia_new (TerritorioCommons *commons)
{
+ GtkWindow *w_main;
GtkWidget *dialog;
GtkWidget *carea;
GtkWidget *connection;
+ SolipaProgressWindow *w_progress;
+
GdaEx *gdaex;
gchar *sql;
GdaDataModel *dm;
GdaDataModelIter *iter;
+ guint rows;
+ gdouble fract;
+ gdouble fract_tot;
+
GdaDataModel *dm_territorio;
const GdaDsnInfo *dsn;
guint id_vie;
+ gchar *nome;
+ gchar *m1_comu_cod;
+ gchar *m1_via_cap;
TerritorioImportaVieCivilia *a = TERRITORIO_IMPORTA_VIECIVILIA (g_object_new (territorio_importa_viecivilia_get_type (), NULL));
priv->commons = commons;
- GtkWindow *w_main = GTK_WINDOW (gtk_builder_get_object (priv->commons->gtkbuilder, "w_main"));
+ w_main = GTK_WINDOW (gtk_builder_get_object (priv->commons->gtkbuilder, "w_main"));
dialog = gtk_dialog_new_with_buttons ("Immettere i parametri di connessione al database Civilia dal quale importare",
w_main,
{
dsn = gdaui_login_get_connection_information (GDAUI_LOGIN (connection));
gdaex = gdaex_new_from_string (g_strdup_printf ("%s://%s;%s", dsn->provider, dsn->cnc_string, dsn->auth_string));
+ gtk_widget_destroy (dialog);
if (gdaex == NULL)
{
- gtk_widget_destroy (dialog);
dialog = gtk_message_dialog_new (w_main,
GTK_DIALOG_DESTROY_WITH_PARENT,
GTK_MESSAGE_WARNING,
if (dm != NULL)
{
+ rows = gda_data_model_get_n_rows (dm);
+ if (rows > 0)
+ {
+ w_progress = solipa_progress_window_new (priv->commons->solipa);
+ g_object_set (G_OBJECT (w_progress),
+ "title", "Importazione vie da Civilia",
+ "label", "",
+ "with-label", FALSE,
+ "with-cancel-button", FALSE,
+ "with-percentage", TRUE,
+ NULL);
+ solipa_progress_window_run (w_progress, w_main);
+
+ fract = 1.0 / (gdouble)rows;
+ fract_tot = 0.0 - fract;
+ }
+
iter = gda_data_model_create_iter (dm);
while (gda_data_model_iter_move_next (iter))
{
+ fract_tot += fract;
+ solipa_progress_window_set_fraction (w_progress, fract_tot);
+ while (gtk_events_pending ()) gtk_main_iteration ();
+
+ nome = gdaex_strescape (gdaex_data_model_iter_get_field_value_stringify_at (iter, "M1_VIA_DESC"), NULL);
+ if (g_strcmp0 (nome, "") == 0)
+ {
+ g_free (nome);
+ continue;
+ }
+
+ m1_comu_cod = g_strdup_printf ("%06d", gdaex_data_model_iter_get_field_value_integer_at (iter, "M1_COMU_COD"));
+ m1_via_cap = gdaex_strescape (gdaex_data_model_iter_get_field_value_stringify_at (iter, "M1_VIA_CAP"), NULL);
+
/* controllo se esiste */
sql = g_strdup_printf ("SELECT v.id"
" FROM vie AS v INNER JOIN comuni AS c ON v.id_comuni = c.id"
" INNER JOIN province AS p ON c.id_province = p.id"
" WHERE p.cod_istat || c.cod_istat = '%s'"
" AND v.nome = '%s'",
- g_strdup_printf ("%06d", gdaex_data_model_iter_get_field_value_integer_at (iter, "M1_COMU_COD")),
- gdaex_strescape (gdaex_data_model_iter_get_field_value_stringify_at (iter, "M1_VIA_DESC"), NULL));
+ m1_comu_cod,
+ nome);
dm_territorio = gdaex_query (priv->commons->gdaex, sql);
+ g_free (sql);
if (dm_territorio == NULL || gda_data_model_get_n_rows (dm_territorio) < 1)
{
/* trovo un nuovo id */
id_vie = 0;
sql = g_strdup_printf ("SELECT COALESCE (MAX (id), 0) FROM vie");
dm_territorio = gdaex_query (priv->commons->gdaex, sql);
- if (dm_territorio != NULL && gda_data_model_get_n_rows (dm_territorio) > 0)
+ g_free (sql);
+ if (dm_territorio != NULL)
{
- id_vie = gdaex_data_model_get_value_integer_at (dm_territorio, 0, 0);
+ if (gda_data_model_get_n_rows (dm_territorio) > 0)
+ {
+ id_vie = gdaex_data_model_get_value_integer_at (dm_territorio, 0, 0);
+ }
+ g_object_unref (dm_territorio);
}
id_vie++;
" (SELECT c.id FROM comuni AS c INNER JOIN province AS p ON c.id_province = p.id WHERE p.cod_istat || c.cod_istat = '%s'),"
" '%s')",
id_vie,
- gdaex_strescape (gdaex_data_model_iter_get_field_value_stringify_at (iter, "M1_VIA_DESC"), NULL),
- g_strdup_printf ("%06d", gdaex_data_model_iter_get_field_value_integer_at (iter, "M1_COMU_COD")),
- gdaex_strescape (gdaex_data_model_iter_get_field_value_stringify_at (iter, "M1_VIA_CAP"), NULL));
+ nome,
+ m1_comu_cod,
+ m1_via_cap);
if (gdaex_execute (priv->commons->gdaex, sql) == -1)
{
- gtk_widget_destroy (dialog);
+ g_free (sql);
+ g_object_unref (w_progress);
dialog = gtk_message_dialog_new (w_main,
GTK_DIALOG_DESTROY_WITH_PARENT,
GTK_MESSAGE_WARNING,
gtk_widget_destroy (dialog);
return NULL;
}
+ g_free (sql);
}
else
{
+ if (dm_territorio != NULL)
+ {
+ g_object_unref (dm_territorio);
+ }
+
/* aggiorno la via */
id_vie = gdaex_data_model_get_value_integer_at (dm_territorio, 0, 0);
+ sql = g_strdup_printf ("UPDATE vie"
+ " SET nome = '%s',"
+ " id_comuni = (SELECT c.id FROM comuni AS c INNER JOIN province AS p ON c.id_province = p.id WHERE p.cod_istat || c.cod_istat = '%s'),"
+ " cap = '%s'"
+ " WHERE id = %d",
+ nome,
+ m1_comu_cod,
+ m1_via_cap,
+ id_vie);
+ if (gdaex_execute (priv->commons->gdaex, sql) == -1)
+ {
+ g_free (sql);
+ g_object_unref (w_progress);
+ dialog = gtk_message_dialog_new (w_main,
+ GTK_DIALOG_DESTROY_WITH_PARENT,
+ GTK_MESSAGE_WARNING,
+ GTK_BUTTONS_OK,
+ "Errore durante il salvataggio della via: %s.",
+ gdaex_data_model_iter_get_field_value_stringify_at (iter, "M1_VIA_DESC"));
+ gtk_dialog_run (GTK_DIALOG (dialog));
+ gtk_widget_destroy (dialog);
+ return NULL;
+ }
+ g_free (sql);
}
+
+ g_free (nome);
+ g_free (m1_comu_cod);
+ g_free (m1_via_cap);
+ }
+
+ if (rows > 0)
+ {
+ g_object_unref (w_progress);
}
}
else
gtk_widget_destroy (dialog);
return NULL;
}
+
+ gdaex_free (gdaex);
}
else
{