2 * Copyright (C) 2006, 2007 John Costigan.
4 * POI and GPS-Info code originally written by Cezary Jackiewicz.
6 * Default map data provided by http://www.openstreetmap.org/
8 * This file is part of Maemo Mapper.
10 * Maemo Mapper is free software: you can redistribute it and/or modify
11 * it under the terms of the GNU General Public License as published by
12 * the Free Software Foundation, either version 3 of the License, or
13 * (at your option) any later version.
15 * Maemo Mapper is distributed in the hope that it will be useful,
16 * but WITHOUT ANY WARRANTY; without even the implied warranty of
17 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18 * GNU General Public License for more details.
20 * You should have received a copy of the GNU General Public License
21 * along with Maemo Mapper. If not, see <http://www.gnu.org/licenses/>.
34 # include <hildon/hildon-help.h>
35 # include <hildon/hildon-note.h>
36 # include <hildon/hildon-file-chooser-dialog.h>
37 # include <hildon/hildon-number-editor.h>
38 # include <hildon/hildon-banner.h>
40 # include <osso-helplib.h>
41 # include <hildon-widgets/hildon-note.h>
42 # include <hildon-widgets/hildon-file-chooser-dialog.h>
43 # include <hildon-widgets/hildon-number-editor.h>
44 # include <hildon-widgets/hildon-banner.h>
45 # include <hildon-widgets/hildon-input-mode-hint.h>
55 #include "gdk-pixbuf-rotate.h"
61 static sqlite3 *_poi_db = NULL;
62 static sqlite3_stmt *_stmt_browse_poi = NULL;
63 static sqlite3_stmt *_stmt_browsecat_poi = NULL;
64 static sqlite3_stmt *_stmt_select_poi = NULL;
65 static sqlite3_stmt *_stmt_select_nearest_poi = NULL;
66 static sqlite3_stmt *_stmt_insert_poi = NULL;
67 static sqlite3_stmt *_stmt_update_poi = NULL;
68 static sqlite3_stmt *_stmt_delete_poi = NULL;
69 static sqlite3_stmt *_stmt_delete_poi_by_catid = NULL;
70 static sqlite3_stmt *_stmt_nextlabel_poi = NULL;
71 static sqlite3_stmt *_stmt_select_cat = NULL;
72 static sqlite3_stmt *_stmt_insert_cat = NULL;
73 static sqlite3_stmt *_stmt_update_cat = NULL;
74 static sqlite3_stmt *_stmt_delete_cat = NULL;
75 static sqlite3_stmt *_stmt_toggle_cat = NULL;
76 static sqlite3_stmt *_stmt_selall_cat = NULL;
78 typedef struct _PoiListInfo PoiListInfo;
83 GtkTreeViewColumn *select_column;
88 typedef struct _OriginToggleInfo OriginToggleInfo;
89 struct _OriginToggleInfo {
90 GtkWidget *rad_use_gps;
91 GtkWidget *rad_use_route;
92 GtkWidget *rad_use_text;
93 GtkWidget *txt_origin;
97 typedef struct _PoiCategoryEditInfo PoiCategoryEditInfo;
98 struct _PoiCategoryEditInfo
101 GtkWidget *cmb_category;
103 GtkWidget *tree_view;
106 /** Data used during action: add or edit category/poi **/
107 typedef struct _DeletePOI DeletePOI;
121 gchar *db_dirname = NULL;
122 printf("%s()\n", __PRETTY_FUNCTION__);
126 sqlite3_close(_poi_db);
130 if(!_poi_db_filename)
134 else if(NULL == (db_dirname = g_path_get_dirname(_poi_db_filename))
135 || (g_mkdir_with_parents(db_dirname, 0755), /* comma operator */
136 (SQLITE_OK != (sqlite3_open(_poi_db_filename, &_poi_db)))))
138 gchar buffer2[BUFFER_SIZE];
139 snprintf(buffer2, sizeof(buffer2),
140 "%s: %s", _("Error with POI database"),
141 sqlite3_errmsg(_poi_db));
142 sqlite3_close(_poi_db);
144 popup_error(_window, buffer2);
146 else if(SQLITE_OK != sqlite3_get_table(_poi_db,
147 "select label from poi limit 1",
148 &pszResult, &nRow, &nColumn, NULL))
150 gchar *create_sql = sqlite3_mprintf(
151 "create table poi (poi_id integer PRIMARY KEY, lat real, "
152 "lon real, label text, desc text, cat_id integer);"
153 "create table category (cat_id integer PRIMARY KEY,"
154 "label text, desc text, enabled integer);"
155 /* Add some default categories... */
156 "insert into category (label, desc, enabled) "
157 "values ('%q', '%q', 1); "
158 "insert into category (label, desc, enabled) "
159 "values ('%q', '%q', 1); "
160 "insert into category (label, desc, enabled) "
161 "values ('%q', '%q', 1); "
162 "insert into category (label, desc, enabled) "
163 "values ('%q', '%q', 1); "
164 "insert into category (label, desc, enabled) "
165 "values ('%q', '%q', 1); "
166 "insert into category (label, desc, enabled) "
167 "values ('%q', '%q', 1); "
168 "insert into category (label, desc, enabled) "
169 "values ('%q', '%q', 1); "
170 "insert into category (label, desc, enabled) "
171 "values ('%q', '%q', 1); "
172 "insert into category (label, desc, enabled) "
173 "values ('%q', '%q', 1); "
174 "insert into category (label, desc, enabled) "
175 "values ('%q', '%q', 1); "
176 "insert into category (label, desc, enabled) "
177 "values ('%q', '%q', 1); ",
178 _("Service Station"),
179 _("Stations for purchasing fuel for vehicles."),
181 _("Houses, apartments, or other residences of import."),
183 _("Places to eat or drink."),
184 _("Shopping/Services"),
185 _("Places to shop or acquire services."),
187 _("Indoor or Outdoor places to have fun."),
189 _("Bus stops, airports, train stations, etc."),
191 _("Places to stay temporarily or for the night."),
193 _("Elementary schools, college campuses, etc."),
195 _("General places of business."),
197 _("General landmarks."),
199 _("Miscellaneous category for everything else."));
201 if(SQLITE_OK != sqlite3_exec(_poi_db, create_sql, NULL, NULL, NULL)
202 && (SQLITE_OK != sqlite3_get_table(_poi_db,
203 "select label from poi limit 1",
204 &pszResult, &nRow, &nColumn, NULL)))
206 snprintf(buffer, sizeof(buffer), "%s:\n%s",
207 _("Failed to open or create database"),
208 sqlite3_errmsg(_poi_db));
209 sqlite3_close(_poi_db);
211 popup_error(_window, buffer);
215 sqlite3_free_table(pszResult);
221 /* Prepare our SQL statements. */
223 sqlite3_prepare(_poi_db,
224 "select p.poi_id, p.cat_id, p.lat, p.lon,"
225 " p.label, p.desc, c.label"
226 " from poi p inner join category c"
227 " on p.cat_id = c.cat_id"
228 " where c.enabled = 1"
229 " and p.label like $QUERY or p.desc like $QUERY"
230 " order by (($LAT - p.lat) * ($LAT - p.lat) "
231 "+ ($LON - p.lon) * ($LON - p.lon)) DESC",
232 -1, &_stmt_browse_poi, NULL);
234 /* browse poi by category */
235 sqlite3_prepare(_poi_db,
236 "select p.poi_id, p.cat_id, p.lat, p.lon,"
237 " p.label, p.desc, c.label"
238 " from poi p inner join category c"
239 " on p.cat_id = c.cat_id"
240 " where c.enabled = 1"
241 " and p.cat_id = $CATID"
242 " and ( p.label like $QUERY or p.desc like $QUERY )"
243 " order by (($LAT - p.lat) * ($LAT - p.lat) "
244 "+ ($LON - p.lon) * ($LON - p.lon)) DESC",
245 -1, &_stmt_browsecat_poi, NULL);
247 /* Prepare our SQL statements. */
248 /* select from poi */
249 sqlite3_prepare(_poi_db,
250 "select p.lat, p.lon, p.poi_id, p.label, p.desc,"
251 " p.cat_id, c.label, c.desc"
252 " from poi p inner join category c"
253 " on p.cat_id = c.cat_id"
254 " where c.enabled = 1"
255 " and p.lat between ? and ? "
256 " and p.lon between ? and ? ",
257 -1, &_stmt_select_poi, NULL);
259 /* select nearest pois */
260 sqlite3_prepare(_poi_db,
261 "select p.poi_id, p.cat_id, p.lat, p.lon,"
262 " p.label, p.desc, c.label"
263 " from poi p inner join category c"
264 " on p.cat_id = c.cat_id"
265 " where c.enabled = 1"
266 " order by (($LAT - p.lat) * ($LAT - p.lat) "
267 "+ ($LON - p.lon) * ($LON - p.lon)) limit 1",
268 -1, &_stmt_select_nearest_poi, NULL);
271 sqlite3_prepare(_poi_db,
272 "insert into poi (lat, lon, label, desc, cat_id)"
273 " values (?, ?, ?, ?, ?)",
274 -1, &_stmt_insert_poi, NULL);
276 sqlite3_prepare(_poi_db,
277 "update poi set lat = ?, lon = ?, "
278 "label = ?, desc = ?, cat_id = ? where poi_id = ?",
279 -1, &_stmt_update_poi, NULL);
280 /* delete from poi */
281 sqlite3_prepare(_poi_db,
282 " delete from poi where poi_id = ?",
283 -1, &_stmt_delete_poi, NULL);
284 /* delete from poi by cat_id */
285 sqlite3_prepare(_poi_db,
286 "delete from poi where cat_id = ?",
287 -1, &_stmt_delete_poi_by_catid, NULL);
288 /* get next poilabel */
289 sqlite3_prepare(_poi_db,
290 "select ifnull(max(poi_id) + 1,1) from poi",
291 -1, &_stmt_nextlabel_poi, NULL);
293 /* select from category */
294 sqlite3_prepare(_poi_db,
295 "select c.label, c.desc, c.enabled"
296 " from category c where c.cat_id = ?",
297 -1, &_stmt_select_cat, NULL);
298 /* insert into category */
299 sqlite3_prepare(_poi_db,
300 "insert into category (label, desc, enabled)"
302 -1, &_stmt_insert_cat, NULL);
303 /* update category */
304 sqlite3_prepare(_poi_db,
305 "update category set label = ?, desc = ?,"
306 " enabled = ? where cat_id = ?",
307 -1, &_stmt_update_cat, NULL);
308 /* delete from category */
309 sqlite3_prepare(_poi_db,
310 "delete from category where cat_id = ?",
311 -1, &_stmt_delete_cat, NULL);
312 /* enable category */
313 sqlite3_prepare(_poi_db,
314 "update category set enabled = ?"
316 -1, &_stmt_toggle_cat, NULL);
317 /* select all category */
318 sqlite3_prepare(_poi_db,
319 "select c.cat_id, c.label, c.desc, c.enabled,"
322 " left outer join poi p on c.cat_id = p.cat_id"
323 " group by c.cat_id, c.label, c.desc, c.enabled "
325 -1, &_stmt_selall_cat, NULL);
328 _poi_enabled = _poi_db != NULL;
330 gtk_widget_set_sensitive(_menu_poi_item, _poi_enabled);
331 gtk_widget_set_sensitive(_cmenu_loc_add_poi_item, _poi_enabled);
332 gtk_widget_set_sensitive(_cmenu_loc_download_poi_item, _poi_enabled);
333 gtk_widget_set_sensitive(_cmenu_loc_browse_poi_item, _poi_enabled);
334 gtk_widget_set_sensitive(_cmenu_way_add_poi_item, _poi_enabled);
335 gtk_widget_set_sensitive(_cmenu_poi_submenu, _poi_enabled);
337 vprintf("%s(): return\n", __PRETTY_FUNCTION__);
341 get_nearest_poi(gint unitx, gint unity, PoiInfo *poi)
343 printf("%s(%d, %d)\n", __PRETTY_FUNCTION__, unitx, unity);
346 unit2latlon(unitx, unity, lat, lon);
348 if(SQLITE_OK == sqlite3_bind_double(_stmt_select_nearest_poi, 1, lat)
349 && SQLITE_OK == sqlite3_bind_double(_stmt_select_nearest_poi, 2, lon)
350 && SQLITE_ROW == sqlite3_step(_stmt_select_nearest_poi))
352 poi->poi_id = sqlite3_column_int(_stmt_select_nearest_poi, 0);
353 poi->cat_id = sqlite3_column_int(_stmt_select_nearest_poi, 1);
354 poi->lat = sqlite3_column_double(_stmt_select_nearest_poi, 2);
355 poi->lon = sqlite3_column_double(_stmt_select_nearest_poi, 3);
356 poi->label =g_strdup(sqlite3_column_text(_stmt_select_nearest_poi, 4));
357 poi->desc = g_strdup(sqlite3_column_text(_stmt_select_nearest_poi, 5));
358 poi->clabel=g_strdup(sqlite3_column_text(_stmt_select_nearest_poi, 6));
363 sqlite3_reset(_stmt_select_nearest_poi);
364 vprintf("%s(): return %d\n", __PRETTY_FUNCTION__, result);
369 select_poi(gint unitx, gint unity, PoiInfo *poi, gboolean quick)
372 gdouble lat1, lon1, lat2, lon2;
373 static GtkWidget *dialog = NULL;
374 static GtkWidget *list = NULL;
375 static GtkWidget *sw = NULL;
376 static GtkTreeViewColumn *column = NULL;
377 static GtkCellRenderer *renderer = NULL;
378 GtkListStore *store = NULL;
380 gboolean selected = FALSE;
381 gchar tmp1[LL_FMT_LEN], tmp2[LL_FMT_LEN];
383 printf("%s()\n", __PRETTY_FUNCTION__);
385 x = unitx - pixel2unit(3 * _draw_width);
386 y = unity + pixel2unit(3 * _draw_width);
387 unit2latlon(x, y, lat1, lon1);
389 x = unitx + pixel2unit(3 * _draw_width);
390 y = unity - pixel2unit(3 * _draw_width);
391 unit2latlon(x, y, lat2, lon2);
393 if(SQLITE_OK != sqlite3_bind_double(_stmt_select_poi, 1, lat1) ||
394 SQLITE_OK != sqlite3_bind_double(_stmt_select_poi, 2, lat2) ||
395 SQLITE_OK != sqlite3_bind_double(_stmt_select_poi, 3, lon1) ||
396 SQLITE_OK != sqlite3_bind_double(_stmt_select_poi, 4, lon2))
398 g_printerr("Failed to bind values for _stmt_select_poi\n");
402 /* Initialize store. */
403 store = gtk_list_store_new(POI_NUM_COLUMNS,
404 G_TYPE_BOOLEAN,/* Selected */
405 G_TYPE_INT, /* POI ID */
406 G_TYPE_INT, /* Category ID */
407 G_TYPE_DOUBLE, /* Latitude */
408 G_TYPE_DOUBLE, /* Longitude */
409 G_TYPE_STRING, /* Lat/Lon */
410 G_TYPE_FLOAT, /* Bearing */
411 G_TYPE_FLOAT, /* Distance */
412 G_TYPE_STRING, /* POI Label */
413 G_TYPE_STRING, /* POI Desc. */
414 G_TYPE_STRING);/* Category Label */
416 while(SQLITE_ROW == sqlite3_step(_stmt_select_poi))
419 lat = sqlite3_column_double(_stmt_select_poi, 0);
420 lon = sqlite3_column_double(_stmt_select_poi, 1);
421 lat_format(lat, tmp1);
422 lon_format(lon, tmp2);
423 gtk_list_store_append(store, &iter);
424 gtk_list_store_set(store, &iter,
425 POI_POIID, sqlite3_column_int(_stmt_select_poi, 2),
426 POI_CATID, sqlite3_column_int(_stmt_select_poi, 5),
429 POI_LATLON, g_strdup_printf("%s, %s", tmp1, tmp2),
430 POI_LABEL, sqlite3_column_text(_stmt_select_poi, 3),
431 POI_DESC, sqlite3_column_text(_stmt_select_poi, 4),
432 POI_CLABEL, sqlite3_column_text(_stmt_select_poi, 6),
436 sqlite3_reset(_stmt_select_poi);
441 g_object_unref(G_OBJECT(store));
444 MACRO_BANNER_SHOW_INFO(_window, _("No POIs found."));
449 /* iter is still set to the most-recently added POI. */
450 gtk_tree_model_get(GTK_TREE_MODEL(store),
452 POI_POIID, &(poi->poi_id),
453 POI_CATID, &(poi->cat_id),
454 POI_LAT, &(poi->lat),
455 POI_LON, &(poi->lon),
456 POI_LABEL, &(poi->label),
457 POI_DESC, &(poi->desc),
458 POI_CLABEL, &(poi->clabel),
460 g_object_unref(G_OBJECT(store));
466 g_object_unref(G_OBJECT(store));
467 return get_nearest_poi(unitx, unity, poi);
471 /* There are at least 2 matching POI's - let the user select one. */
474 dialog = gtk_dialog_new_with_buttons(_("Select POI"),
475 GTK_WINDOW(_window), GTK_DIALOG_MODAL,
476 GTK_STOCK_OK, GTK_RESPONSE_ACCEPT,
477 GTK_STOCK_CANCEL, GTK_RESPONSE_REJECT,
480 gtk_window_set_default_size(GTK_WINDOW(dialog), 500, 300);
482 sw = gtk_scrolled_window_new (NULL, NULL);
483 gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (sw),
484 GTK_SHADOW_ETCHED_IN);
485 gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (sw),
487 GTK_POLICY_AUTOMATIC);
488 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialog)->vbox),
491 list = gtk_tree_view_new();
492 gtk_container_add(GTK_CONTAINER(sw), list);
494 gtk_tree_selection_set_mode(
495 gtk_tree_view_get_selection(GTK_TREE_VIEW(list)),
496 GTK_SELECTION_SINGLE);
497 gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(list), TRUE);
499 renderer = gtk_cell_renderer_text_new();
500 column = gtk_tree_view_column_new_with_attributes(
501 _("Location"), renderer, "text", POI_LATLON, NULL);
502 gtk_tree_view_append_column(GTK_TREE_VIEW(list), column);
504 renderer = gtk_cell_renderer_text_new();
505 column = gtk_tree_view_column_new_with_attributes(
506 _("Label"), renderer, "text", POI_LABEL, NULL);
507 gtk_tree_view_append_column(GTK_TREE_VIEW(list), column);
509 renderer = gtk_cell_renderer_text_new();
510 column = gtk_tree_view_column_new_with_attributes(
511 _("Category"), renderer, "text", POI_CLABEL, NULL);
512 gtk_tree_view_append_column(GTK_TREE_VIEW(list), column);
515 gtk_tree_view_set_model(GTK_TREE_VIEW(list), GTK_TREE_MODEL(store));
516 g_object_unref(G_OBJECT(store));
518 gtk_widget_show_all(dialog);
520 while(GTK_RESPONSE_ACCEPT == gtk_dialog_run(GTK_DIALOG(dialog)))
522 if(gtk_tree_selection_get_selected(
523 gtk_tree_view_get_selection(GTK_TREE_VIEW(list)),
526 gtk_tree_model_get(GTK_TREE_MODEL(store), &iter,
527 POI_POIID, &(poi->poi_id),
528 POI_CATID, &(poi->cat_id),
529 POI_LAT, &(poi->lat),
530 POI_LON, &(poi->lon),
531 POI_LABEL, &(poi->label),
532 POI_DESC, &(poi->desc),
533 POI_CLABEL, &(poi->clabel),
539 popup_error(dialog, _("Select one POI from the list."));
544 gtk_widget_hide(dialog);
546 vprintf("%s(): return %d\n", __PRETTY_FUNCTION__, selected);
551 category_delete(GtkWidget *widget, DeletePOI *dpoi)
556 printf("%s()\n", __PRETTY_FUNCTION__);
558 buffer = g_strdup_printf("%s\n\t%s\n%s",
559 _("Delete category?"),
561 _("WARNING: All POIs in that category will also be deleted!"));
562 confirm = hildon_note_new_confirmation(GTK_WINDOW(dpoi->dialog), buffer);
564 i = gtk_dialog_run(GTK_DIALOG(confirm));
565 gtk_widget_destroy(GTK_WIDGET(confirm));
567 if(i == GTK_RESPONSE_OK)
569 /* delete dpoi->poi_id */
570 if(SQLITE_OK != sqlite3_bind_int(_stmt_delete_poi_by_catid, 1,
572 SQLITE_DONE != sqlite3_step(_stmt_delete_poi_by_catid))
574 MACRO_BANNER_SHOW_INFO(dpoi->dialog, _("Error deleting POI"));
575 sqlite3_reset(_stmt_delete_poi_by_catid);
578 sqlite3_reset(_stmt_delete_poi_by_catid);
580 if(SQLITE_OK != sqlite3_bind_int(_stmt_delete_cat, 1, dpoi->id) ||
581 SQLITE_DONE != sqlite3_step(_stmt_delete_cat))
583 MACRO_BANNER_SHOW_INFO(dpoi->dialog, _("Error deleting category"));
584 sqlite3_reset(_stmt_delete_cat);
587 sqlite3_reset(_stmt_delete_cat);
591 gtk_widget_destroy(confirm);
593 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
598 category_edit_dialog(GtkWidget *parent, gint cat_id)
600 gchar *cat_label = NULL, *cat_desc = NULL;
605 GtkWidget *txt_label;
607 GtkWidget *btn_delete = NULL;
608 GtkWidget *txt_scroll;
609 GtkWidget *chk_enabled;
610 GtkTextBuffer *desc_txt;
611 GtkTextIter begin, end;
612 gboolean results = TRUE;
613 DeletePOI dpoi = {NULL, NULL, 0};
614 printf("%s()\n", __PRETTY_FUNCTION__);
618 if(SQLITE_OK != sqlite3_bind_double(_stmt_select_cat, 1, cat_id) ||
619 SQLITE_ROW != sqlite3_step(_stmt_select_cat))
621 vprintf("%s(): return FALSE\n", __PRETTY_FUNCTION__);
622 sqlite3_reset(_stmt_select_cat);
626 cat_label = g_strdup(sqlite3_column_text(_stmt_select_cat, 0));
627 cat_desc = g_strdup(sqlite3_column_text(_stmt_select_cat, 1));
628 cat_enabled = sqlite3_column_int(_stmt_select_cat, 2);
630 sqlite3_reset(_stmt_select_cat);
632 dialog = gtk_dialog_new_with_buttons(_("Edit Category"),
633 GTK_WINDOW(parent), GTK_DIALOG_MODAL,
634 GTK_STOCK_OK, GTK_RESPONSE_ACCEPT,
637 gtk_container_add(GTK_CONTAINER(GTK_DIALOG(dialog)->action_area),
638 btn_delete = gtk_button_new_with_label(_("Delete...")));
640 dpoi.dialog = dialog;
641 dpoi.txt_label = g_strdup(cat_label);
643 dpoi.deleted = FALSE;
645 g_signal_connect(G_OBJECT(btn_delete), "clicked",
646 G_CALLBACK(category_delete), &dpoi);
648 gtk_dialog_add_button(GTK_DIALOG(dialog),
649 GTK_STOCK_CANCEL, GTK_RESPONSE_REJECT);
654 cat_label = g_strdup("");
656 cat_desc = g_strdup("");
658 dialog = gtk_dialog_new_with_buttons(_("Add Category"),
659 GTK_WINDOW(parent), GTK_DIALOG_MODAL,
660 GTK_STOCK_OK, GTK_RESPONSE_ACCEPT,
661 GTK_STOCK_CANCEL, GTK_RESPONSE_REJECT,
665 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialog)->vbox),
666 table = gtk_table_new(6, 4, FALSE), TRUE, TRUE, 0);
668 gtk_table_attach(GTK_TABLE(table),
669 label = gtk_label_new(_("Label")),
670 0, 1, 0, 1, GTK_FILL, 0, 2, 4);
671 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
672 gtk_table_attach(GTK_TABLE(table),
673 txt_label = gtk_entry_new(),
674 1, 2, 0, 1, GTK_EXPAND | GTK_FILL, 0, 2, 4);
676 gtk_table_attach(GTK_TABLE(table),
677 label = gtk_label_new(_("Description")),
678 0, 1, 1, 2, GTK_FILL, 0, 2, 4);
679 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
681 txt_scroll = gtk_scrolled_window_new(NULL, NULL);
682 gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(txt_scroll),
684 gtk_table_attach(GTK_TABLE(table),
686 1, 2, 1, 2, GTK_EXPAND | GTK_FILL, 0, 2, 4);
688 gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(txt_scroll),
689 GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
691 txt_desc = gtk_text_view_new();
692 gtk_text_view_set_wrap_mode(GTK_TEXT_VIEW(txt_desc), GTK_WRAP_WORD);
694 gtk_container_add(GTK_CONTAINER(txt_scroll), txt_desc);
695 gtk_widget_set_size_request(GTK_WIDGET(txt_scroll), 400, 60);
697 desc_txt = gtk_text_view_get_buffer(GTK_TEXT_VIEW(txt_desc));
699 gtk_table_attach(GTK_TABLE(table),
700 chk_enabled = gtk_check_button_new_with_label(
702 0, 2, 2, 3, GTK_EXPAND | GTK_FILL, 0, 2, 4);
705 gtk_entry_set_text(GTK_ENTRY(txt_label), cat_label);
708 gtk_text_buffer_set_text(desc_txt, cat_desc, -1);
711 gtk_toggle_button_set_active(GTK_TOGGLE_BUTTON(chk_enabled),
712 (cat_enabled == 1 ? TRUE : FALSE));
719 gtk_widget_show_all(dialog);
721 while(GTK_RESPONSE_ACCEPT == gtk_dialog_run(GTK_DIALOG(dialog)))
723 if(strlen(gtk_entry_get_text(GTK_ENTRY(txt_label))))
724 cat_label = g_strdup(gtk_entry_get_text(GTK_ENTRY(txt_label)));
727 popup_error(dialog, _("Please specify a name for the category."));
731 gtk_text_buffer_get_iter_at_offset(desc_txt, &begin,0 );
732 gtk_text_buffer_get_end_iter (desc_txt, &end);
733 cat_desc = gtk_text_buffer_get_text(desc_txt, &begin, &end, TRUE);
735 cat_enabled = (gtk_toggle_button_get_active(
736 GTK_TOGGLE_BUTTON(chk_enabled)) ? 1 : 0);
741 if(SQLITE_OK != sqlite3_bind_text(_stmt_update_cat, 1, cat_label,
743 SQLITE_OK != sqlite3_bind_text(_stmt_update_cat, 2, cat_desc,
745 SQLITE_OK != sqlite3_bind_int(_stmt_update_cat, 3,cat_enabled)||
746 SQLITE_OK != sqlite3_bind_int(_stmt_update_cat, 4, cat_id) ||
747 SQLITE_DONE != sqlite3_step(_stmt_update_cat))
749 MACRO_BANNER_SHOW_INFO(parent,_("Error updating category"));
752 sqlite3_reset(_stmt_update_cat);
757 if(SQLITE_OK != sqlite3_bind_text(_stmt_insert_cat, 1, cat_label,
759 SQLITE_OK != sqlite3_bind_text(_stmt_insert_cat, 2, cat_desc,
761 SQLITE_OK != sqlite3_bind_int(_stmt_insert_cat, 3,cat_enabled)||
762 SQLITE_DONE != sqlite3_step(_stmt_insert_cat))
764 MACRO_BANNER_SHOW_INFO(parent, _("Error adding category"));
767 sqlite3_reset(_stmt_insert_cat);
772 g_free(dpoi.txt_label);
774 g_object_unref (desc_txt);
779 gtk_widget_hide(dialog);
781 vprintf("%s(): return\n", __PRETTY_FUNCTION__);
786 category_toggled(GtkCellRendererToggle *cell, gchar *path, GtkListStore *data)
789 gboolean cat_enabled;
791 printf("%s()\n", __PRETTY_FUNCTION__);
793 GtkTreeModel *model = GTK_TREE_MODEL(data);
794 if( !gtk_tree_model_get_iter_from_string(model, &iter, path) )
797 gtk_tree_model_get(model, &iter,
798 CAT_ENABLED, &cat_enabled,
804 if(SQLITE_OK != sqlite3_bind_int(_stmt_toggle_cat, 1, cat_enabled) ||
805 SQLITE_OK != sqlite3_bind_int(_stmt_toggle_cat, 2, cat_id) ||
806 SQLITE_DONE != sqlite3_step(_stmt_toggle_cat))
808 MACRO_BANNER_SHOW_INFO(_window, _("Error updating Category"));
812 gtk_list_store_set(GTK_LIST_STORE(model), &iter,
813 CAT_ENABLED, cat_enabled, -1);
817 sqlite3_reset(_stmt_toggle_cat);
819 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
827 printf("%s()\n", __PRETTY_FUNCTION__);
829 store = gtk_list_store_new(CAT_NUM_COLUMNS,
836 while(SQLITE_ROW == sqlite3_step(_stmt_selall_cat))
838 gtk_list_store_append(store, &iter);
839 gtk_list_store_set(store, &iter,
840 CAT_ID, sqlite3_column_int(_stmt_selall_cat, 0),
841 CAT_ENABLED, sqlite3_column_int(_stmt_selall_cat, 3),
842 CAT_LABEL, sqlite3_column_text(_stmt_selall_cat, 1),
843 CAT_DESC, sqlite3_column_text(_stmt_selall_cat, 2),
844 CAT_POI_CNT, sqlite3_column_int(_stmt_selall_cat, 4),
847 sqlite3_reset(_stmt_selall_cat);
849 vprintf("%s(): return %p\n", __PRETTY_FUNCTION__, store);
854 category_add(GtkWidget *widget, PoiCategoryEditInfo *pcedit)
857 printf("%s()\n", __PRETTY_FUNCTION__);
859 if(category_edit_dialog(pcedit->dialog, 0))
861 store = generate_store();
862 gtk_tree_view_set_model(
863 GTK_TREE_VIEW(pcedit->tree_view),
864 GTK_TREE_MODEL(store));
865 g_object_unref(G_OBJECT(store));
867 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
872 category_edit(GtkWidget *widget, PoiCategoryEditInfo *pcedit)
876 GtkTreeSelection *selection;
877 printf("%s()\n", __PRETTY_FUNCTION__);
879 store = gtk_tree_view_get_model(GTK_TREE_VIEW(pcedit->tree_view));
880 selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(pcedit->tree_view));
881 if(gtk_tree_selection_get_selected(selection, &store, &iter))
884 memset(&val, 0, sizeof(val));
885 gtk_tree_model_get_value(store, &iter, 0, &val);
886 if(category_edit_dialog(pcedit->dialog, g_value_get_uint(&val)))
888 GtkListStore *new_store = generate_store();
889 gtk_tree_view_set_model(
890 GTK_TREE_VIEW(pcedit->tree_view),
891 GTK_TREE_MODEL(new_store));
892 g_object_unref(G_OBJECT(new_store));
895 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
900 category_list_dialog(GtkWidget *parent)
902 static GtkWidget *dialog = NULL;
903 static GtkWidget *tree_view = NULL;
904 static GtkWidget *sw = NULL;
905 static GtkWidget *btn_edit = NULL;
906 static GtkWidget *btn_add = NULL;
907 static GtkTreeViewColumn *column = NULL;
908 static GtkCellRenderer *renderer = NULL;
909 static GtkListStore *store;
910 static PoiCategoryEditInfo pcedit;
911 printf("%s()\n", __PRETTY_FUNCTION__);
913 store = generate_store();
918 dialog = gtk_dialog_new_with_buttons(_("POI Categories"),
919 GTK_WINDOW(parent), GTK_DIALOG_MODAL,
920 GTK_STOCK_OK, GTK_RESPONSE_ACCEPT,
923 /* Enable the help button. */
925 hildon_help_dialog_help_enable(
927 ossohelp_dialog_help_enable(
929 GTK_DIALOG(dialog), HELP_ID_POICAT, _osso);
931 gtk_container_add(GTK_CONTAINER(GTK_DIALOG(dialog)->action_area),
932 btn_edit = gtk_button_new_with_label(_("Edit...")));
934 gtk_container_add(GTK_CONTAINER(GTK_DIALOG(dialog)->action_area),
935 btn_add = gtk_button_new_with_label(_("Add...")));
937 sw = gtk_scrolled_window_new(NULL, NULL);
938 gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW (sw),
940 GTK_POLICY_AUTOMATIC);
941 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialog)->vbox),
944 tree_view = gtk_tree_view_new();
946 g_object_set(tree_view, "allow-checkbox-mode", FALSE, NULL);
947 gtk_container_add (GTK_CONTAINER (sw), tree_view);
949 gtk_tree_selection_set_mode(
950 gtk_tree_view_get_selection(GTK_TREE_VIEW(tree_view)),
951 GTK_SELECTION_SINGLE);
952 gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(tree_view), TRUE);
954 renderer = gtk_cell_renderer_text_new();
955 column = gtk_tree_view_column_new_with_attributes(
956 _("ID"), renderer, "text", CAT_ID, NULL);
957 gtk_tree_view_append_column(GTK_TREE_VIEW(tree_view), column);
958 gtk_tree_view_column_set_max_width (column, 1);
960 renderer = gtk_cell_renderer_toggle_new();
961 g_signal_connect (renderer, "toggled",
962 G_CALLBACK (category_toggled), store);
963 column = gtk_tree_view_column_new_with_attributes(
964 _("Enabled"), renderer, "active", CAT_ENABLED, NULL);
965 gtk_tree_view_append_column(GTK_TREE_VIEW(tree_view), column);
967 renderer = gtk_cell_renderer_text_new();
968 column = gtk_tree_view_column_new_with_attributes(
969 _("Label"), renderer, "text", CAT_LABEL, NULL);
970 gtk_tree_view_append_column(GTK_TREE_VIEW(tree_view), column);
972 renderer = gtk_cell_renderer_text_new();
973 column = gtk_tree_view_column_new_with_attributes(
974 _("Description"), renderer, "text", CAT_DESC, NULL);
975 gtk_tree_view_append_column(GTK_TREE_VIEW(tree_view), column);
977 renderer = gtk_cell_renderer_text_new();
978 column = gtk_tree_view_column_new_with_attributes(
979 _("# POIs"), renderer, "text", CAT_POI_CNT, NULL);
980 gtk_tree_view_append_column(GTK_TREE_VIEW(tree_view), column);
982 gtk_window_set_default_size(GTK_WINDOW(dialog), -1, 400);
984 pcedit.dialog = dialog;
985 pcedit.tree_view = tree_view;
987 g_signal_connect(G_OBJECT(btn_edit), "clicked",
988 G_CALLBACK(category_edit), &pcedit);
990 g_signal_connect(G_OBJECT(btn_add), "clicked",
991 G_CALLBACK(category_add), &pcedit);
993 gtk_tree_view_set_model(GTK_TREE_VIEW(tree_view), GTK_TREE_MODEL(store));
994 g_object_unref(G_OBJECT(store));
996 gtk_widget_show_all(dialog);
998 while(GTK_RESPONSE_ACCEPT == gtk_dialog_run(GTK_DIALOG(dialog)))
1003 gtk_widget_destroy(dialog);
1005 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
1010 poi_delete(GtkWidget *widget, DeletePOI *dpoi)
1015 printf("%s()\n", __PRETTY_FUNCTION__);
1017 buffer = g_strdup_printf("%s\n%s", _("Delete POI?"), dpoi->txt_label);
1018 confirm = hildon_note_new_confirmation(GTK_WINDOW(dpoi->dialog), buffer);
1020 i = gtk_dialog_run(GTK_DIALOG(confirm));
1021 gtk_widget_destroy(GTK_WIDGET(confirm));
1023 if(i == GTK_RESPONSE_OK)
1025 if(SQLITE_OK != sqlite3_bind_int(_stmt_delete_poi, 1, dpoi->id) ||
1026 SQLITE_DONE != sqlite3_step(_stmt_delete_poi))
1028 MACRO_BANNER_SHOW_INFO(dpoi->dialog, _("Error deleting POI"));
1032 dpoi->deleted = TRUE;
1033 gtk_widget_hide(dpoi->dialog);
1036 sqlite3_reset(_stmt_delete_poi);
1039 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
1044 poi_populate_categories(GtkListStore *store, gint cat_id,
1045 GtkTreeIter *out_active)
1047 gboolean has_active = FALSE;
1048 printf("%s()\n", __PRETTY_FUNCTION__);
1050 gtk_list_store_clear(store);
1052 while(SQLITE_ROW == sqlite3_step(_stmt_selall_cat))
1055 gint cid = sqlite3_column_int(_stmt_selall_cat, 0);
1056 const gchar *clab = sqlite3_column_text(_stmt_selall_cat, 1);
1058 gtk_list_store_append(store, &iter);
1059 gtk_list_store_set(store, &iter, 0, cid, 1, clab, -1);
1061 if(cid == cat_id || !has_active)
1068 sqlite3_reset(_stmt_selall_cat);
1070 vprintf("%s(): return\n", __PRETTY_FUNCTION__);
1075 poi_edit_cat(GtkWidget *widget, PoiCategoryEditInfo *data)
1077 printf("%s()\n", __PRETTY_FUNCTION__);
1078 if(category_list_dialog(data->dialog))
1081 if(poi_populate_categories(GTK_LIST_STORE(gtk_combo_box_get_model(
1082 GTK_COMBO_BOX(data->cmb_category))),
1083 data->cat_id, &active))
1085 gtk_combo_box_set_active_iter(
1086 GTK_COMBO_BOX(data->cmb_category), &active);
1089 vprintf("%s(): return\n", __PRETTY_FUNCTION__);
1094 poi_create_cat_combo()
1096 GtkWidget *cmb_category;
1097 GtkTreeModel *model;
1098 printf("%s()\n", __PRETTY_FUNCTION__);
1100 model = GTK_TREE_MODEL(gtk_list_store_new(2,
1101 G_TYPE_INT, /* Category ID */
1102 G_TYPE_STRING)); /* Category Label */
1103 cmb_category = gtk_combo_box_new_with_model(model);
1104 g_object_unref(model);
1106 /* Set up the view for the combo box. */
1108 GtkCellRenderer *renderer;
1110 renderer = gtk_cell_renderer_text_new();
1111 gtk_cell_layout_pack_start(
1112 GTK_CELL_LAYOUT(cmb_category), renderer, TRUE);
1113 gtk_cell_layout_set_attributes(
1114 GTK_CELL_LAYOUT(cmb_category), renderer, "text", 1, NULL);
1116 poi_populate_categories(GTK_LIST_STORE(gtk_combo_box_get_model(
1117 GTK_COMBO_BOX(cmb_category))), -1, &active);
1119 vprintf("%s(): return\n", __PRETTY_FUNCTION__);
1120 return cmb_category;
1124 poi_add_dialog(GtkWidget *parent, gint unitx, gint unity)
1128 static GtkWidget *dialog;
1129 static GtkWidget *table;
1130 static GtkWidget *label;
1131 static GtkWidget *txt_label;
1132 static GtkWidget *txt_lat;
1133 static GtkWidget *txt_lon;
1134 static GtkWidget *cmb_category;
1135 static GtkWidget *txt_desc;
1136 static GtkWidget *btn_catedit;
1137 static GtkWidget *hbox;
1138 static GtkWidget *txt_scroll;
1139 static GtkTextBuffer *desc_txt;
1140 static GtkTextIter begin, end;
1141 static DeletePOI dpoi = {NULL, NULL, 0};
1142 static PoiCategoryEditInfo pcedit;
1143 printf("%s()\n", __PRETTY_FUNCTION__);
1147 dialog = gtk_dialog_new_with_buttons(_("Add POI"),
1148 GTK_WINDOW(parent), GTK_DIALOG_MODAL,
1149 GTK_STOCK_OK, GTK_RESPONSE_ACCEPT,
1150 GTK_STOCK_CANCEL, GTK_RESPONSE_REJECT,
1153 /* Set the lat/lon strings. */
1154 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialog)->vbox),
1155 table = gtk_table_new(6, 4, FALSE), TRUE, TRUE, 0);
1157 gtk_table_attach(GTK_TABLE(table),
1158 label = gtk_label_new(_("Lat")),
1159 0, 1, 0, 1, GTK_FILL, 0, 2, 0);
1160 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
1161 gtk_table_attach(GTK_TABLE(table),
1162 txt_lat = gtk_entry_new(),
1163 1, 2, 0, 1, GTK_FILL, 0, 2, 0);
1165 gtk_table_attach(GTK_TABLE(table),
1166 label = gtk_label_new(_("Lon")),
1167 2, 3, 0, 1, GTK_FILL, 0, 2, 0);
1168 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
1169 gtk_table_attach(GTK_TABLE(table),
1170 txt_lon = gtk_entry_new(),
1171 3, 4, 0, 1, GTK_FILL, 0, 2, 0);
1173 gtk_table_attach(GTK_TABLE(table),
1174 label = gtk_label_new(_("Label")),
1175 0, 1, 1, 2, GTK_FILL, 0, 2, 0);
1176 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
1177 gtk_table_attach(GTK_TABLE(table),
1178 txt_label = gtk_entry_new(),
1179 1, 4, 1, 2, GTK_EXPAND | GTK_FILL, 0, 2, 0);
1181 gtk_table_attach(GTK_TABLE(table),
1182 label = gtk_label_new(_("Category")),
1183 0, 1, 3, 4, GTK_FILL, 0, 2, 0);
1184 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
1185 gtk_table_attach(GTK_TABLE(table),
1186 hbox = gtk_hbox_new(FALSE, 4),
1187 1, 4, 3, 4, GTK_EXPAND | GTK_FILL, 0, 2, 0);
1188 gtk_box_pack_start(GTK_BOX(hbox),
1189 cmb_category = poi_create_cat_combo(),
1192 gtk_box_pack_start(GTK_BOX(hbox),
1193 btn_catedit = gtk_button_new_with_label(
1194 _("Edit Categories...")),
1197 gtk_table_attach(GTK_TABLE(table),
1198 label = gtk_label_new(_("Description")),
1199 0, 1, 5, 6, GTK_FILL, GTK_FILL, 2, 0);
1200 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.0f);
1202 txt_scroll = gtk_scrolled_window_new(NULL, NULL);
1203 gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(txt_scroll),
1205 gtk_table_attach(GTK_TABLE(table),
1207 1, 4, 5, 6, GTK_EXPAND | GTK_FILL, 0, 2, 0);
1209 gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(txt_scroll),
1210 GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
1212 txt_desc = gtk_text_view_new ();
1213 gtk_text_view_set_wrap_mode(GTK_TEXT_VIEW(txt_desc), GTK_WRAP_WORD);
1215 gtk_container_add(GTK_CONTAINER(txt_scroll), txt_desc);
1216 gtk_widget_set_size_request(GTK_WIDGET(txt_scroll), 550, 120);
1218 desc_txt = gtk_text_view_get_buffer(GTK_TEXT_VIEW (txt_desc));
1220 g_signal_connect(G_OBJECT(btn_catedit), "clicked",
1221 G_CALLBACK(poi_edit_cat), &pcedit);
1227 poi.desc = g_strdup("");
1228 unit2latlon(unitx, unity, poi.lat, poi.lon);
1231 snprintf(buffer, sizeof(buffer), "%.06f", poi.lat);
1232 gtk_entry_set_text(GTK_ENTRY(txt_lat), buffer);
1233 snprintf(buffer, sizeof(buffer), "%.06f", poi.lon);
1234 gtk_entry_set_text(GTK_ENTRY(txt_lon), buffer);
1237 if(SQLITE_ROW == sqlite3_step(_stmt_nextlabel_poi))
1238 poi.label = g_strdup_printf("Point%06d",
1239 sqlite3_column_int(_stmt_nextlabel_poi, 0));
1241 poi.label = g_strdup("");
1242 sqlite3_reset(_stmt_nextlabel_poi);
1243 gtk_entry_set_text(GTK_ENTRY(txt_label), poi.label);
1246 gtk_text_buffer_set_text(desc_txt, "", -1);
1252 gboolean had_cat_id = FALSE;
1254 if(gtk_combo_box_get_active_iter(
1255 GTK_COMBO_BOX(cmb_category), &iter))
1258 gtk_combo_box_get_model(GTK_COMBO_BOX(cmb_category)),&iter,
1263 gtk_list_store_clear(GTK_LIST_STORE(gtk_combo_box_get_model(
1264 GTK_COMBO_BOX(cmb_category))));
1265 if(poi_populate_categories(GTK_LIST_STORE(gtk_combo_box_get_model(
1266 GTK_COMBO_BOX(cmb_category))), cat_id, &iter)
1269 gtk_combo_box_set_active_iter(GTK_COMBO_BOX(cmb_category), &iter);
1273 pcedit.dialog = dialog;
1274 pcedit.cmb_category = cmb_category;
1275 pcedit.cat_id = poi.cat_id;
1277 gtk_widget_show_all(dialog);
1279 while(GTK_RESPONSE_ACCEPT == gtk_dialog_run(GTK_DIALOG(dialog)))
1285 text = gtk_entry_get_text(GTK_ENTRY(txt_lat));
1286 poi.lat = strdmstod(text, &error_check);
1287 if(text == error_check || poi.lat < -90. || poi.lat > 90.) {
1288 popup_error(dialog, _("Invalid Latitude"));
1292 text = gtk_entry_get_text(GTK_ENTRY(txt_lon));
1293 poi.lon = strdmstod(text, &error_check);
1294 if(text == error_check || poi.lon < -180. || poi.lon > 180.) {
1295 popup_error(dialog, _("Invalid Longitude"));
1299 if(strlen(gtk_entry_get_text(GTK_ENTRY(txt_label))))
1303 poi.label = g_strdup(gtk_entry_get_text(GTK_ENTRY(txt_label)));
1307 popup_error(dialog, _("Please specify a name."));
1311 if(!gtk_combo_box_get_active_iter(
1312 GTK_COMBO_BOX(cmb_category), &iter))
1314 popup_error(dialog, _("Please specify a category."));
1318 gtk_text_buffer_get_iter_at_offset(desc_txt, &begin,0 );
1319 gtk_text_buffer_get_end_iter (desc_txt, &end);
1322 poi.desc = gtk_text_buffer_get_text(desc_txt, &begin, &end, TRUE);
1327 gtk_combo_box_get_model(GTK_COMBO_BOX(cmb_category)), &iter,
1333 if(SQLITE_OK != sqlite3_bind_double(_stmt_insert_poi, 1, poi.lat)
1334 || SQLITE_OK != sqlite3_bind_double(_stmt_insert_poi, 2, poi.lon)
1335 || SQLITE_OK != sqlite3_bind_text(_stmt_insert_poi, 3, poi.label,
1337 || SQLITE_OK != sqlite3_bind_text(_stmt_insert_poi, 4, poi.desc,
1339 || SQLITE_OK != sqlite3_bind_int(_stmt_insert_poi, 5, poi.cat_id)
1340 || SQLITE_DONE != sqlite3_step(_stmt_insert_poi))
1342 MACRO_BANNER_SHOW_INFO(parent, _("Error adding POI"));
1345 sqlite3_reset(_stmt_insert_poi);
1353 g_free(dpoi.txt_label);
1357 gtk_widget_hide(dialog);
1359 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
1360 return !dpoi.deleted;
1364 poi_view_dialog(GtkWidget *parent, PoiInfo *poi)
1367 static GtkWidget *dialog;
1368 static GtkWidget *table;
1369 static GtkWidget *label;
1370 static GtkWidget *txt_label;
1371 static GtkWidget *txt_lat;
1372 static GtkWidget *txt_lon;
1373 static GtkWidget *cmb_category;
1374 static GtkWidget *txt_desc;
1375 static GtkWidget *btn_delete = NULL;
1376 static GtkWidget *btn_catedit;
1377 static GtkWidget *hbox;
1378 static GtkWidget *txt_scroll;
1379 static GtkTextBuffer *desc_txt;
1380 static GtkTextIter begin, end;
1381 static DeletePOI dpoi = {NULL, NULL, 0};
1382 static PoiCategoryEditInfo pcedit;
1383 printf("%s()\n", __PRETTY_FUNCTION__);
1387 dialog = gtk_dialog_new_with_buttons(_("Edit POI"),
1388 GTK_WINDOW(parent), GTK_DIALOG_MODAL,
1389 GTK_STOCK_OK, GTK_RESPONSE_ACCEPT,
1392 gtk_container_add(GTK_CONTAINER(GTK_DIALOG(dialog)->action_area),
1393 btn_delete = gtk_button_new_with_label(_("Delete...")));
1395 gtk_dialog_add_button(GTK_DIALOG(dialog),
1396 GTK_STOCK_CANCEL, GTK_RESPONSE_REJECT);
1398 /* Set the lat/lon strings. */
1399 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialog)->vbox),
1400 table = gtk_table_new(6, 4, FALSE), TRUE, TRUE, 0);
1402 gtk_table_attach(GTK_TABLE(table),
1403 label = gtk_label_new(_("Lat")),
1404 0, 1, 0, 1, GTK_FILL, 0, 2, 0);
1405 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
1406 gtk_table_attach(GTK_TABLE(table),
1407 txt_lat = gtk_entry_new(),
1408 1, 2, 0, 1, GTK_FILL, 0, 2, 0);
1410 gtk_table_attach(GTK_TABLE(table),
1411 label = gtk_label_new(_("Lon")),
1412 2, 3, 0, 1, GTK_FILL, 0, 2, 0);
1413 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
1414 gtk_table_attach(GTK_TABLE(table),
1415 txt_lon = gtk_entry_new(),
1416 3, 4, 0, 1, GTK_FILL, 0, 2, 0);
1418 gtk_table_attach(GTK_TABLE(table),
1419 label = gtk_label_new(_("Label")),
1420 0, 1, 1, 2, GTK_FILL, 0, 2, 0);
1421 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
1422 gtk_table_attach(GTK_TABLE(table),
1423 txt_label = gtk_entry_new(),
1424 1, 4, 1, 2, GTK_EXPAND | GTK_FILL, 0, 2, 0);
1426 gtk_table_attach(GTK_TABLE(table),
1427 label = gtk_label_new(_("Category")),
1428 0, 1, 3, 4, GTK_FILL, 0, 2, 0);
1429 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
1430 gtk_table_attach(GTK_TABLE(table),
1431 hbox = gtk_hbox_new(FALSE, 4),
1432 1, 4, 3, 4, GTK_EXPAND | GTK_FILL, 0, 2, 0);
1433 gtk_box_pack_start(GTK_BOX(hbox),
1434 cmb_category = poi_create_cat_combo(),
1437 gtk_box_pack_start(GTK_BOX(hbox),
1438 btn_catedit = gtk_button_new_with_label(
1439 _("Edit Categories...")),
1442 gtk_table_attach(GTK_TABLE(table),
1443 label = gtk_label_new(_("Description")),
1444 0, 1, 5, 6, GTK_FILL, GTK_FILL, 2, 0);
1445 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.0f);
1447 txt_scroll = gtk_scrolled_window_new(NULL, NULL);
1448 gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(txt_scroll),
1450 gtk_table_attach(GTK_TABLE(table),
1452 1, 4, 5, 6, GTK_EXPAND | GTK_FILL, 0, 2, 0);
1454 gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(txt_scroll),
1455 GTK_POLICY_AUTOMATIC, GTK_POLICY_AUTOMATIC);
1457 txt_desc = gtk_text_view_new ();
1458 gtk_text_view_set_wrap_mode(GTK_TEXT_VIEW(txt_desc), GTK_WRAP_WORD);
1460 gtk_container_add(GTK_CONTAINER(txt_scroll), txt_desc);
1461 gtk_widget_set_size_request(GTK_WIDGET(txt_scroll), 550, 120);
1463 desc_txt = gtk_text_view_get_buffer (GTK_TEXT_VIEW (txt_desc));
1465 g_signal_connect(G_OBJECT(btn_delete), "clicked",
1466 G_CALLBACK(poi_delete), &dpoi);
1468 g_signal_connect(G_OBJECT(btn_catedit), "clicked",
1469 G_CALLBACK(poi_edit_cat), &pcedit);
1472 dpoi.dialog = dialog;
1473 dpoi.txt_label = g_strdup(poi->label);
1474 dpoi.id = poi->poi_id;
1475 dpoi.deleted = FALSE;
1479 gchar tmp1[LL_FMT_LEN], tmp2[LL_FMT_LEN];
1481 lat_format(poi->lat, tmp1);
1482 lon_format(poi->lon, tmp2);
1484 gtk_entry_set_text(GTK_ENTRY(txt_lat), tmp2);
1485 gtk_entry_set_text(GTK_ENTRY(txt_lon), tmp1);
1489 gtk_entry_set_text(GTK_ENTRY(txt_label), poi->label);
1492 gtk_text_buffer_set_text(desc_txt, poi->desc, -1);
1495 gtk_list_store_clear(GTK_LIST_STORE(gtk_combo_box_get_model(
1496 GTK_COMBO_BOX(cmb_category))));
1497 if(poi_populate_categories(GTK_LIST_STORE(gtk_combo_box_get_model(
1498 GTK_COMBO_BOX(cmb_category))), poi->cat_id, &iter))
1499 gtk_combo_box_set_active_iter(GTK_COMBO_BOX(cmb_category), &iter);
1501 /* Connect Signals */
1502 pcedit.dialog = dialog;
1503 pcedit.cmb_category = cmb_category;
1504 pcedit.cat_id = poi->cat_id;
1506 gtk_widget_show_all(dialog);
1508 while(GTK_RESPONSE_ACCEPT == gtk_dialog_run(GTK_DIALOG(dialog)))
1513 text = gtk_entry_get_text(GTK_ENTRY(txt_lat));
1514 poi->lat = strdmstod(text, &error_check);
1515 if(text == error_check || poi->lat < -90. || poi->lat > 90.) {
1516 popup_error(dialog, _("Invalid Latitude"));
1520 text = gtk_entry_get_text(GTK_ENTRY(txt_lon));
1521 poi->lon = strdmstod(text, &error_check);
1522 if(text == error_check || poi->lon < -180. || poi->lon > 180.) {
1523 popup_error(dialog, _("Invalid Longitude"));
1527 if(strlen(gtk_entry_get_text(GTK_ENTRY(txt_label))))
1531 poi->label = g_strdup(gtk_entry_get_text(GTK_ENTRY(txt_label)));
1535 popup_error(dialog, _("Please specify a name."));
1539 if(!gtk_combo_box_get_active_iter(
1540 GTK_COMBO_BOX(cmb_category), &iter))
1542 popup_error(dialog, _("Please specify a category."));
1546 gtk_text_buffer_get_iter_at_offset(desc_txt, &begin,0 );
1547 gtk_text_buffer_get_end_iter (desc_txt, &end);
1550 poi->desc = gtk_text_buffer_get_text(desc_txt, &begin, &end, TRUE);
1553 g_free(poi->clabel);
1555 gtk_combo_box_get_model(GTK_COMBO_BOX(cmb_category)), &iter,
1561 if(SQLITE_OK != sqlite3_bind_double(
1562 _stmt_update_poi, 1, poi->lat) ||
1563 SQLITE_OK != sqlite3_bind_double(
1564 _stmt_update_poi, 2, poi->lon) ||
1565 SQLITE_OK != sqlite3_bind_text(_stmt_update_poi, 3, poi->label,
1566 -1, SQLITE_STATIC) ||
1567 SQLITE_OK != sqlite3_bind_text(_stmt_update_poi, 4, poi->desc,
1569 SQLITE_OK != sqlite3_bind_int(
1570 _stmt_update_poi, 5, poi->cat_id) ||
1571 SQLITE_OK != sqlite3_bind_int(
1572 _stmt_update_poi, 6, poi->poi_id) ||
1573 SQLITE_DONE != sqlite3_step(_stmt_update_poi))
1575 MACRO_BANNER_SHOW_INFO(parent, _("Error updating POI"));
1578 sqlite3_reset(_stmt_update_poi);
1584 g_free(dpoi.txt_label);
1588 gtk_widget_hide(dialog); /* Destroying causes a crash.... ??? */
1590 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
1591 return !dpoi.deleted;
1595 poi_list_insert(GtkWidget *parent, GList *poi_list, GtkComboBox *cmb_category)
1597 gint default_cat_id;
1598 gchar *default_cat_label;
1599 gint num_inserts = 0;
1602 printf("%s()\n", __PRETTY_FUNCTION__);
1604 /* Get defaults from the given GtkComboBox */
1605 if(!gtk_combo_box_get_active_iter(
1606 GTK_COMBO_BOX(cmb_category), &iter))
1608 vprintf("%s(): return 0\n", __PRETTY_FUNCTION__);
1612 gtk_combo_box_get_model(GTK_COMBO_BOX(cmb_category)),
1615 1, &default_cat_label,
1618 /* Iterate through the data model and import as desired. */
1619 for(curr = poi_list; curr; )
1621 PoiInfo *poi = curr->data;
1623 ( SQLITE_OK != sqlite3_bind_double(_stmt_insert_poi, 1, poi->lat)
1624 || SQLITE_OK != sqlite3_bind_double(_stmt_insert_poi, 2, poi->lon)
1625 || SQLITE_OK != sqlite3_bind_text(_stmt_insert_poi, 3, poi->label,
1627 || SQLITE_OK != sqlite3_bind_text(_stmt_insert_poi, 4, poi->desc,
1629 || SQLITE_OK != sqlite3_bind_int(_stmt_insert_poi, 5,
1630 poi->cat_id = default_cat_id)
1631 || SQLITE_DONE != sqlite3_step(_stmt_insert_poi)
1635 GList *tmp = curr->next;
1640 g_slice_free(PoiInfo, poi);
1641 poi_list = g_list_delete_link(poi_list, curr);
1648 if(default_cat_label)
1649 poi->clabel = g_strdup(default_cat_label);
1650 poi->poi_id = sqlite3_last_insert_rowid(_poi_db);
1653 sqlite3_reset(_stmt_insert_poi);
1658 gchar buffer[BUFFER_SIZE];
1660 snprintf(buffer, sizeof(buffer), "%d %s", num_inserts,
1661 _("POIs were added to the POI database. The following screen will "
1662 "allow you to modify or delete any of the new POIs."));
1663 popup_error(parent, buffer);
1667 popup_error(parent, _("No POIs were found."));
1670 if(default_cat_label)
1671 g_free(default_cat_label);
1673 vprintf("%s(): return %d\n", __PRETTY_FUNCTION__, num_inserts);
1678 poi_list_free(GList *poi_list)
1681 printf("%s()\n", __PRETTY_FUNCTION__);
1683 for(curr = poi_list; curr; curr = curr->next)
1685 PoiInfo *poi_info = curr->data;
1689 g_free(poi_info->label);
1691 g_free(poi_info->desc);
1692 if(poi_info->clabel)
1693 g_free(poi_info->clabel);
1694 g_slice_free(PoiInfo, poi_info);
1698 g_list_free(poi_list);
1700 vprintf("%s(): return\n", __PRETTY_FUNCTION__);
1704 poi_list_bearing_cell_data_func(
1705 GtkTreeViewColumn *tree_column,
1706 GtkCellRenderer *cell,
1707 GtkTreeModel *tree_model,
1712 vprintf("%s()\n", __PRETTY_FUNCTION__);
1714 gtk_tree_model_get(tree_model, iter, POI_BEARING, &f, -1);
1715 snprintf(buffer, sizeof(buffer), "%.1f", f);
1716 g_object_set(cell, "text", buffer, NULL);
1718 vprintf("%s(): return\n", __PRETTY_FUNCTION__);
1722 poi_list_distance_cell_data_func(
1723 GtkTreeViewColumn *tree_column,
1724 GtkCellRenderer *cell,
1725 GtkTreeModel *tree_model,
1730 vprintf("%s()\n", __PRETTY_FUNCTION__);
1732 gtk_tree_model_get(tree_model, iter, POI_DISTANCE, &f, -1);
1733 snprintf(buffer, sizeof(buffer), "%.2f", f);
1734 g_object_set(cell, "text", buffer, NULL);
1736 vprintf("%s(): return\n", __PRETTY_FUNCTION__);
1740 poi_list_row_selected(GtkCellRendererToggle *renderer,
1741 gchar *path_string, GtkTreeModel *tree_model)
1744 vprintf("%s()\n", __PRETTY_FUNCTION__);
1746 if(gtk_tree_model_get_iter_from_string(tree_model, &iter, path_string))
1749 gtk_tree_model_get(tree_model, &iter, POI_SELECTED, &old_value, -1);
1750 gtk_list_store_set(GTK_LIST_STORE(tree_model), &iter,
1751 POI_SELECTED, !old_value,
1755 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
1760 poi_list_set_category(GtkWidget *widget, PoiListInfo *pli)
1762 static GtkWidget *dialog = NULL;
1763 static GtkWidget *cmb_category = NULL;
1764 static GtkWidget *btn_catedit = NULL;
1765 static PoiCategoryEditInfo pcedit;
1766 printf("%s()\n", __PRETTY_FUNCTION__);
1773 dialog = gtk_dialog_new_with_buttons(_("Set Category..."),
1774 GTK_WINDOW(pli->dialog2), GTK_DIALOG_MODAL,
1775 GTK_STOCK_OK, GTK_RESPONSE_ACCEPT,
1776 GTK_STOCK_CANCEL, GTK_RESPONSE_REJECT,
1779 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialog)->vbox),
1780 hbox = gtk_hbox_new(FALSE, 4), FALSE, FALSE, 4);
1782 gtk_box_pack_start(GTK_BOX(hbox),
1783 label = gtk_label_new(_("Category")),
1786 gtk_box_pack_start(GTK_BOX(hbox),
1787 cmb_category = poi_create_cat_combo(),
1790 gtk_box_pack_start(GTK_BOX(hbox),
1791 btn_catedit = gtk_button_new_with_label(
1792 _("Edit Categories...")),
1795 /* Connect Signals */
1796 pcedit.dialog = dialog;
1797 pcedit.cmb_category = cmb_category;
1799 g_signal_connect(G_OBJECT(btn_catedit), "clicked",
1800 G_CALLBACK(poi_edit_cat), &pcedit);
1803 gtk_widget_show_all(dialog);
1805 while(GTK_RESPONSE_ACCEPT == gtk_dialog_run(GTK_DIALOG(dialog)))
1808 GtkListStore *store;
1810 const gchar *cat_label;
1812 /* Get the text of the chosen category. */
1813 if(!gtk_combo_box_get_active_iter(
1814 GTK_COMBO_BOX(cmb_category), &iter))
1816 popup_error(dialog, _("Please specify a category."));
1821 gtk_combo_box_get_model(GTK_COMBO_BOX(cmb_category)),
1827 /* Iterate through the data store and categorize as desired. */
1828 store = GTK_LIST_STORE(gtk_tree_view_get_model(
1829 GTK_TREE_VIEW(pli->tree_view)));
1830 if(gtk_tree_model_get_iter_first(GTK_TREE_MODEL(store), &iter)) do
1835 memset(&poi, 0, sizeof(poi));
1837 gtk_tree_model_get(GTK_TREE_MODEL(store), &iter,
1838 POI_SELECTED, &selected,
1839 POI_POIID, &(poi.poi_id),
1840 POI_LAT, &(poi.lat),
1841 POI_LON, &(poi.lon),
1842 POI_LABEL, &(poi.label),
1843 POI_DESC, &(poi.desc),
1848 gtk_list_store_set(store, &iter,
1850 POI_CLABEL, cat_label,
1853 if(SQLITE_OK != sqlite3_bind_double(
1854 _stmt_update_poi, 1, poi.lat) ||
1855 SQLITE_OK != sqlite3_bind_double(
1856 _stmt_update_poi, 2, poi.lon) ||
1857 SQLITE_OK != sqlite3_bind_text(_stmt_update_poi,
1858 3, poi.label, -1, SQLITE_STATIC) ||
1859 SQLITE_OK != sqlite3_bind_text(_stmt_update_poi,
1860 4, poi.desc, -1, SQLITE_STATIC) ||
1861 SQLITE_OK != sqlite3_bind_int(
1862 _stmt_update_poi, 5, cat_id) ||
1863 SQLITE_OK != sqlite3_bind_int(
1864 _stmt_update_poi, 6, poi.poi_id) ||
1865 SQLITE_DONE != sqlite3_step(_stmt_update_poi))
1867 MACRO_BANNER_SHOW_INFO(pli->dialog2,
1868 _("Error updating POI"));
1870 sqlite3_reset(_stmt_update_poi);
1872 } while(gtk_tree_model_iter_next(GTK_TREE_MODEL(store), &iter));
1878 gtk_widget_hide(dialog);
1880 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
1885 poi_list_select_all(GtkTreeViewColumn *column, PoiListInfo *pli)
1888 GtkListStore *store;
1889 printf("%s()\n", __PRETTY_FUNCTION__);
1891 /* Iterate through the data store and select as desired. */
1892 store = GTK_LIST_STORE(gtk_tree_view_get_model(
1893 GTK_TREE_VIEW(pli->tree_view)));
1894 if(gtk_tree_model_get_iter_first(GTK_TREE_MODEL(store), &iter)) do
1896 gtk_list_store_set(store, &iter,
1897 POI_SELECTED, pli->select_all,
1899 } while(gtk_tree_model_iter_next(GTK_TREE_MODEL(store), &iter));
1901 pli->select_all = !pli->select_all;
1903 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
1908 poi_list_view(GtkWidget *widget, PoiListInfo *pli)
1911 GtkTreeSelection *selection;
1912 GtkListStore *store;
1913 printf("%s()\n", __PRETTY_FUNCTION__);
1915 selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(pli->tree_view));
1916 store = GTK_LIST_STORE(gtk_tree_view_get_model(
1917 GTK_TREE_VIEW(pli->tree_view)));
1919 /* Iterate through the data store and import as desired. */
1920 if(gtk_tree_selection_get_selected(selection, NULL, &iter))
1923 memset(&poi, 0, sizeof(poi));
1925 gtk_tree_model_get(GTK_TREE_MODEL(store), &iter,
1926 POI_POIID, &(poi.poi_id),
1927 POI_CATID, &(poi.cat_id),
1928 POI_LAT, &(poi.lat),
1929 POI_LON, &(poi.lon),
1930 POI_LABEL, &(poi.label),
1931 POI_DESC, &(poi.desc),
1932 POI_CLABEL, &(poi.clabel),
1935 if(poi_view_dialog(pli->dialog, &poi))
1937 gtk_list_store_set(store, &iter,
1938 POI_POIID, poi.poi_id,
1939 POI_CATID, poi.cat_id,
1942 POI_LABEL, poi.label,
1944 POI_CLABEL, poi.clabel,
1949 /* POI was deleted. */
1950 gtk_list_store_remove(store, &iter);
1954 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
1959 poi_list_row_activated(GtkTreeView *tree_view, GtkTreePath *path,
1960 GtkTreeViewColumn *column, PoiListInfo *pli)
1962 printf("%s()\n", __PRETTY_FUNCTION__);
1964 if(column != pli->select_column)
1965 poi_list_view(GTK_WIDGET(tree_view), pli);
1967 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
1971 poi_list_goto(GtkWidget *widget, PoiListInfo *pli)
1974 GtkTreeSelection *selection;
1975 GtkListStore *store;
1976 printf("%s()\n", __PRETTY_FUNCTION__);
1978 selection = gtk_tree_view_get_selection(GTK_TREE_VIEW(pli->tree_view));
1979 store = GTK_LIST_STORE(gtk_tree_view_get_model(
1980 GTK_TREE_VIEW(pli->tree_view)));
1982 /* Iterate through the data store and import as desired. */
1983 if(gtk_tree_selection_get_selected(selection, NULL, &iter))
1988 gtk_tree_model_get(GTK_TREE_MODEL(store), &iter,
1993 latlon2unit(lat, lon, unit.unitx, unit.unity);
1995 if(_center_mode > 0)
1996 gtk_check_menu_item_set_active(
1997 GTK_CHECK_MENU_ITEM(_menu_view_ac_none_item), TRUE);
1999 map_center_unit(unit);
2002 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
2007 poi_list_delete(GtkWidget *widget, PoiListInfo *pli)
2010 printf("%s()\n", __PRETTY_FUNCTION__);
2012 confirm = hildon_note_new_confirmation(
2013 GTK_WINDOW(pli->dialog2), _("Delete selected POI?"));
2015 if(GTK_RESPONSE_OK == gtk_dialog_run(GTK_DIALOG(confirm)))
2018 GtkListStore *store;
2019 gboolean already_next;
2020 gboolean must_iterate;;
2022 /* Iterate through the data store and import as desired. */
2023 store = GTK_LIST_STORE(gtk_tree_view_get_model(
2024 GTK_TREE_VIEW(pli->tree_view)));
2025 if(gtk_tree_model_get_iter_first(GTK_TREE_MODEL(store), &iter)) do
2028 must_iterate = TRUE;
2029 already_next = FALSE;
2031 gtk_tree_model_get(GTK_TREE_MODEL(store), &iter,
2032 POI_SELECTED, &selected,
2038 if(SQLITE_OK != sqlite3_bind_int(_stmt_delete_poi, 1, poi_id)
2039 || SQLITE_DONE != sqlite3_step(_stmt_delete_poi))
2041 MACRO_BANNER_SHOW_INFO(pli->dialog2,
2042 _("Error deleting POI"));
2046 already_next = gtk_list_store_remove(store, &iter);
2047 must_iterate = FALSE;
2049 sqlite3_reset(_stmt_delete_poi);
2051 } while(already_next || (must_iterate
2052 && gtk_tree_model_iter_next(GTK_TREE_MODEL(store), &iter)));
2057 gtk_widget_destroy(confirm);
2059 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
2064 poi_list_export_gpx(GtkWidget *widget, PoiListInfo *pli)
2066 GnomeVFSHandle *handle;
2067 printf("%s()\n", __PRETTY_FUNCTION__);
2069 if(display_open_file(pli->dialog2, NULL, &handle, NULL, NULL, NULL,
2070 GTK_FILE_CHOOSER_ACTION_SAVE))
2072 gint num_exported = gpx_poi_write(
2073 gtk_tree_view_get_model(GTK_TREE_VIEW(pli->tree_view)), handle);
2074 if(num_exported >= 0)
2077 snprintf(buffer, sizeof(buffer), "%d %s\n", num_exported,
2078 _("POIs Exported"));
2079 MACRO_BANNER_SHOW_INFO(pli->dialog2, buffer);
2082 popup_error(pli->dialog2, _("Error writing GPX file."));
2083 gnome_vfs_close(handle);
2086 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
2091 poi_list_manage_checks(GtkWidget *widget, PoiListInfo *pli)
2093 GtkWidget *btn_category;
2094 GtkWidget *btn_delete;
2095 GtkWidget *btn_export_gpx;
2097 printf("%s()\n", __PRETTY_FUNCTION__);
2099 pli->dialog2 = gtk_dialog_new_with_buttons(_("Checked POI Actions..."),
2100 GTK_WINDOW(pli->dialog), GTK_DIALOG_MODAL,
2103 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(pli->dialog2)->vbox),
2104 gtk_label_new(_("Select an operation to perform\n"
2105 "on the POIs that you checked\n"
2106 "in the POI list.")),
2109 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(pli->dialog2)->vbox),
2110 btn_category = gtk_button_new_with_label(_("Set Category...")),
2113 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(pli->dialog2)->vbox),
2114 btn_delete = gtk_button_new_with_label(_("Delete...")),
2117 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(pli->dialog2)->vbox),
2118 btn_export_gpx = gtk_button_new_with_label(
2119 _("Export to GPX...")),
2122 gtk_dialog_add_button(GTK_DIALOG(pli->dialog2),
2123 GTK_STOCK_CLOSE, GTK_RESPONSE_ACCEPT);
2125 g_signal_connect(G_OBJECT(btn_category), "clicked",
2126 G_CALLBACK(poi_list_set_category), pli);
2128 g_signal_connect(G_OBJECT(btn_delete), "clicked",
2129 G_CALLBACK(poi_list_delete), pli);
2131 g_signal_connect(G_OBJECT(btn_export_gpx), "clicked",
2132 G_CALLBACK(poi_list_export_gpx), pli);
2134 gtk_widget_show_all(pli->dialog2);
2136 gtk_dialog_run(GTK_DIALOG(pli->dialog2));
2138 gtk_widget_destroy(pli->dialog2);
2139 pli->dialog2 = NULL;
2141 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
2146 poi_list_dialog(GtkWidget *parent, gint unitx, gint unity, GList *poi_list)
2148 static PoiListInfo pli = { NULL, NULL };
2149 static GtkWidget *scroller;
2150 static GtkWidget *btn_goto;
2151 static GtkWidget *btn_edit;
2152 static GtkWidget *btn_manage_checks;
2153 static GtkListStore *store;
2156 gdouble src_lat, src_lon;
2157 printf("%s()\n", __PRETTY_FUNCTION__);
2159 if(pli.dialog == NULL)
2161 GtkCellRenderer *renderer;
2162 GtkTreeViewColumn *column;
2164 pli.dialog = gtk_dialog_new_with_buttons(_("POI List"),
2165 GTK_WINDOW(parent), GTK_DIALOG_MODAL,
2168 store = gtk_list_store_new(POI_NUM_COLUMNS,
2169 G_TYPE_BOOLEAN,/* Selected */
2170 G_TYPE_INT, /* POI ID */
2171 G_TYPE_INT, /* Category ID */
2172 G_TYPE_DOUBLE, /* Latitude */
2173 G_TYPE_DOUBLE, /* Longitude */
2174 G_TYPE_STRING, /* Lat/Lon */
2175 G_TYPE_FLOAT, /* Bearing */
2176 G_TYPE_FLOAT, /* Distance */
2177 G_TYPE_STRING, /* POI Label */
2178 G_TYPE_STRING, /* POI Desc. */
2179 G_TYPE_STRING);/* Category Label */
2181 /* Set up the tree view. */
2182 pli.tree_view = gtk_tree_view_new();
2183 g_object_set(G_OBJECT(pli.tree_view),
2184 "allow-checkbox-mode", FALSE, NULL);
2186 gtk_tree_selection_set_mode(
2187 gtk_tree_view_get_selection(GTK_TREE_VIEW(pli.tree_view)),
2188 GTK_SELECTION_SINGLE);
2189 gtk_tree_view_set_headers_visible(GTK_TREE_VIEW(pli.tree_view), TRUE);
2191 renderer = gtk_cell_renderer_toggle_new();
2192 gtk_cell_renderer_toggle_set_active(GTK_CELL_RENDERER_TOGGLE(renderer),
2194 g_signal_connect(G_OBJECT(renderer), "toggled",
2195 G_CALLBACK(poi_list_row_selected), store);
2196 pli.select_column = gtk_tree_view_column_new_with_attributes(
2197 "*", renderer, "active", POI_SELECTED, NULL);
2198 gtk_tree_view_append_column(GTK_TREE_VIEW(pli.tree_view),
2200 gtk_tree_view_column_set_clickable(pli.select_column, TRUE);
2201 g_signal_connect(G_OBJECT(pli.select_column), "clicked",
2202 G_CALLBACK(poi_list_select_all), &pli);
2204 renderer = gtk_cell_renderer_combo_new();
2205 column = gtk_tree_view_column_new_with_attributes(
2206 _("Category"), renderer, "text", POI_CLABEL, NULL);
2207 gtk_tree_view_column_set_sizing(column,GTK_TREE_VIEW_COLUMN_GROW_ONLY);
2208 gtk_tree_view_column_set_sort_column_id(column, POI_CLABEL);
2209 gtk_tree_view_append_column(GTK_TREE_VIEW(pli.tree_view), column);
2211 renderer = gtk_cell_renderer_text_new();
2212 g_object_set(renderer, "xalign", 1.f, NULL);
2213 column = gtk_tree_view_column_new_with_attributes(
2214 _("Dist."), renderer, "text", POI_DISTANCE, NULL);
2215 gtk_tree_view_column_set_cell_data_func(column, renderer,
2216 (GtkTreeCellDataFunc)poi_list_distance_cell_data_func,
2218 gtk_tree_view_column_set_sort_column_id(column, POI_DISTANCE);
2219 gtk_tree_view_append_column(GTK_TREE_VIEW(pli.tree_view), column);
2221 renderer = gtk_cell_renderer_text_new();
2222 g_object_set(renderer, "xalign", 1.f, NULL);
2223 column = gtk_tree_view_column_new_with_attributes(
2224 _("Bear."), renderer, "text", POI_BEARING, NULL);
2225 gtk_tree_view_column_set_cell_data_func(column, renderer,
2226 (GtkTreeCellDataFunc)poi_list_bearing_cell_data_func,
2228 gtk_tree_view_column_set_sort_column_id(column, POI_BEARING);
2229 gtk_tree_view_append_column(GTK_TREE_VIEW(pli.tree_view), column);
2231 renderer = gtk_cell_renderer_text_new();
2232 column = gtk_tree_view_column_new_with_attributes(
2233 _("Label"), renderer, "text", POI_LABEL, NULL);
2234 gtk_tree_view_column_set_sort_column_id(column, POI_LABEL);
2235 gtk_tree_view_append_column(GTK_TREE_VIEW(pli.tree_view), column);
2237 g_signal_connect(G_OBJECT(pli.tree_view), "row-activated",
2238 G_CALLBACK(poi_list_row_activated), &pli);
2240 gtk_tree_view_set_model(GTK_TREE_VIEW(pli.tree_view),
2241 GTK_TREE_MODEL(store));
2242 g_object_unref(G_OBJECT(store));
2244 /* Enable the help button. */
2246 hildon_help_dialog_help_enable(
2248 ossohelp_dialog_help_enable(
2250 GTK_DIALOG(pli.dialog), HELP_ID_POILIST, _osso);
2252 gtk_container_add(GTK_CONTAINER(GTK_DIALOG(pli.dialog)->action_area),
2253 btn_goto = gtk_button_new_with_label(_("Go to")));
2255 gtk_container_add(GTK_CONTAINER(GTK_DIALOG(pli.dialog)->action_area),
2256 btn_edit = gtk_button_new_with_label(_("Edit...")));
2258 gtk_container_add(GTK_CONTAINER(GTK_DIALOG(pli.dialog)->action_area),
2259 btn_manage_checks = gtk_button_new_with_label(
2260 _("Checked POI Actions...")));
2262 gtk_dialog_add_button(GTK_DIALOG(pli.dialog),
2263 GTK_STOCK_CLOSE, GTK_RESPONSE_ACCEPT);
2265 gtk_window_set_default_size(GTK_WINDOW(pli.dialog), 500, 400);
2267 scroller = gtk_scrolled_window_new (NULL, NULL);
2268 gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(scroller),
2269 GTK_SHADOW_ETCHED_IN);
2270 gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scroller),
2272 GTK_POLICY_AUTOMATIC);
2273 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(pli.dialog)->vbox),
2274 scroller, TRUE, TRUE, 0);
2276 gtk_container_add(GTK_CONTAINER(scroller), pli.tree_view);
2278 g_signal_connect(G_OBJECT(btn_goto), "clicked",
2279 G_CALLBACK(poi_list_goto), &pli);
2281 g_signal_connect(G_OBJECT(btn_edit), "clicked",
2282 G_CALLBACK(poi_list_view), &pli);
2284 g_signal_connect(G_OBJECT(btn_manage_checks), "clicked",
2285 G_CALLBACK(poi_list_manage_checks), &pli);
2288 /* Initialize the tree store. */
2290 gtk_list_store_clear(store);
2291 pli.select_all = FALSE;
2293 unit2latlon(unitx, unity, src_lat, src_lon);
2295 for(curr = poi_list; curr; curr = curr->next)
2297 PoiInfo *poi_info = curr->data;
2298 gchar tmp1[LL_FMT_LEN], tmp2[LL_FMT_LEN];
2300 printf("poi: (%f, %f, %s, %s)\n",
2301 poi_info->lat, poi_info->lon,
2302 poi_info->label, poi_info->desc);
2304 lat_format(poi_info->lat, tmp1);
2305 lon_format(poi_info->lon, tmp2);
2307 gtk_list_store_append(store, &iter);
2308 gtk_list_store_set(store, &iter,
2310 POI_POIID, poi_info->poi_id,
2311 POI_LAT, poi_info->lat,
2312 POI_LON, poi_info->lon,
2313 POI_BEARING, calculate_bearing(src_lat, src_lon,
2314 poi_info->lat, poi_info->lon),
2315 POI_DISTANCE, calculate_distance(src_lat,src_lon,
2316 poi_info->lat, poi_info->lon) * UNITS_CONVERT[_units],
2317 POI_LABEL, poi_info->label,
2318 POI_DESC, poi_info->desc,
2319 POI_CATID, poi_info->cat_id,
2320 POI_CLABEL, poi_info->clabel,
2324 gtk_widget_show_all(pli.dialog);
2326 GTK_RESPONSE_ACCEPT == gtk_dialog_run(GTK_DIALOG(pli.dialog));
2330 gtk_widget_hide(pli.dialog);
2332 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
2337 poi_import_dialog(gint unitx, gint unity)
2339 GtkWidget *dialog = NULL;
2340 gboolean success = FALSE;
2341 printf("%s()\n", __PRETTY_FUNCTION__);
2343 dialog = hildon_file_chooser_dialog_new(GTK_WINDOW(_window),
2344 GTK_FILE_CHOOSER_ACTION_OPEN);
2346 gtk_widget_show_all(dialog);
2348 while(!success && gtk_dialog_run(GTK_DIALOG(dialog)) == GTK_RESPONSE_OK)
2350 gchar *file_uri_str = NULL;
2351 gchar *bytes = NULL;
2353 GnomeVFSResult vfs_result;
2354 GList *poi_list = NULL;
2356 file_uri_str = gtk_file_chooser_get_uri(GTK_FILE_CHOOSER(dialog));
2358 /* Parse the given file as GPX. */
2359 if(GNOME_VFS_OK != (vfs_result = gnome_vfs_read_entire_file(
2360 file_uri_str, &size, &bytes)))
2362 popup_error(dialog, gnome_vfs_result_to_string(vfs_result));
2364 else if(gpx_poi_parse(bytes, size, &poi_list))
2366 static GtkWidget *cat_dialog = NULL;
2367 static GtkWidget *cmb_category = NULL;
2368 static GtkWidget *btn_catedit = NULL;
2369 static PoiCategoryEditInfo pcedit;
2375 cat_dialog = gtk_dialog_new_with_buttons(_("Default Category"),
2376 GTK_WINDOW(dialog), GTK_DIALOG_MODAL,
2377 GTK_STOCK_OK, GTK_RESPONSE_ACCEPT,
2378 GTK_STOCK_CANCEL, GTK_RESPONSE_REJECT,
2381 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(cat_dialog)->vbox),
2382 hbox = gtk_hbox_new(FALSE, 4), FALSE, FALSE, 4);
2384 gtk_box_pack_start(GTK_BOX(hbox),
2385 label = gtk_label_new(_("Category")),
2388 gtk_box_pack_start(GTK_BOX(hbox),
2389 cmb_category = poi_create_cat_combo(),
2392 gtk_box_pack_start(GTK_BOX(hbox),
2393 btn_catedit = gtk_button_new_with_label(
2394 _("Edit Categories...")),
2397 /* Connect Signals */
2398 pcedit.dialog = dialog;
2399 pcedit.cmb_category = cmb_category;
2401 g_signal_connect(G_OBJECT(btn_catedit), "clicked",
2402 G_CALLBACK(poi_edit_cat), &pcedit);
2405 gtk_widget_show_all(cat_dialog);
2407 while(GTK_RESPONSE_ACCEPT ==gtk_dialog_run(GTK_DIALOG(cat_dialog)))
2409 if(gtk_combo_box_get_active(GTK_COMBO_BOX(cmb_category)) == -1)
2412 _("Please specify a default category."));
2416 /* Insert the POIs into the database. */
2417 gint num_inserts = poi_list_insert(dialog,
2418 poi_list, GTK_COMBO_BOX(cmb_category));
2422 /* Hide the dialogs. */
2423 gtk_widget_hide(cat_dialog);
2425 /* Create a new dialog with the results. */
2426 poi_list_dialog(dialog, unitx, unity, poi_list);
2432 gtk_widget_hide(cat_dialog);
2434 poi_list_free(poi_list);
2437 popup_error(dialog, _("Error parsing GPX file."));
2439 g_free(file_uri_str);
2443 /* Hide the dialog. */
2444 gtk_widget_destroy(dialog);
2446 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
2451 poi_download_cat_selected(GtkComboBox *cmb_category, GtkEntry *txt_query)
2454 printf("%s()\n", __PRETTY_FUNCTION__);
2456 if(gtk_combo_box_get_active_iter(GTK_COMBO_BOX(cmb_category), &iter))
2458 gchar buffer[BUFFER_SIZE];
2459 GtkWidget *confirm = NULL;
2460 gchar *category = NULL;
2463 gtk_combo_box_get_model(GTK_COMBO_BOX(cmb_category)), &iter,
2467 if(*gtk_entry_get_text(txt_query))
2469 snprintf(buffer, sizeof(buffer), "%s\n %s",
2470 _("Overwrite query with the following text?"), category);
2471 confirm = hildon_note_new_confirmation(GTK_WINDOW(_window),buffer);
2476 || GTK_RESPONSE_OK == gtk_dialog_run(GTK_DIALOG(confirm)))
2477 gtk_entry_set_text(txt_query, category);
2480 gtk_widget_destroy(confirm);
2483 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
2489 origin_type_selected(GtkWidget *toggle, OriginToggleInfo *oti)
2491 printf("%s()\n", __PRETTY_FUNCTION__);
2493 if(gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(toggle)))
2494 gtk_widget_set_sensitive(oti->txt_origin, toggle == oti->rad_use_text);
2496 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
2501 poi_download_dialog(gint unitx, gint unity)
2503 static GtkWidget *dialog = NULL;
2504 static GtkWidget *hbox = NULL;
2505 static GtkWidget *table = NULL;
2506 static GtkWidget *table2 = NULL;
2507 static GtkWidget *label = NULL;
2508 static GtkWidget *num_page = NULL;
2509 static GtkWidget *txt_source_url = NULL;
2510 static OriginToggleInfo oti;
2511 static GtkWidget *cmb_category;
2512 printf("%s()\n", __PRETTY_FUNCTION__);
2514 conic_recommend_connected();
2518 GtkEntryCompletion *origin_comp;
2520 dialog = gtk_dialog_new_with_buttons(_("Download POIs"),
2521 GTK_WINDOW(_window), GTK_DIALOG_MODAL,
2522 GTK_STOCK_OK, GTK_RESPONSE_ACCEPT,
2523 GTK_STOCK_CANCEL, GTK_RESPONSE_REJECT,
2526 /* Enable the help button. */
2528 hildon_help_dialog_help_enable(
2530 ossohelp_dialog_help_enable(
2532 GTK_DIALOG(dialog), HELP_ID_DOWNPOI, _osso);
2534 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialog)->vbox),
2535 table = gtk_table_new(4, 4, FALSE), TRUE, TRUE, 0);
2538 gtk_table_attach(GTK_TABLE(table),
2539 hbox = gtk_hbox_new(FALSE, 4),
2540 0, 4, 0, 1, GTK_EXPAND | GTK_FILL, 0, 2, 4);
2541 gtk_box_pack_start(GTK_BOX(hbox),
2542 label = gtk_label_new(_("Source URL")), FALSE, TRUE, 4);
2543 gtk_box_pack_start(GTK_BOX(hbox),
2544 txt_source_url = gtk_entry_new(), TRUE, TRUE, 4);
2547 gtk_table_attach(GTK_TABLE(table),
2548 oti.rad_use_gps = gtk_radio_button_new_with_label(NULL,
2549 _("Use GPS Location")),
2550 0, 1, 1, 2, GTK_FILL, 0, 2, 4);
2552 /* Use End of Route. */
2553 gtk_table_attach(GTK_TABLE(table),
2554 oti.rad_use_route = gtk_radio_button_new_with_label_from_widget(
2555 GTK_RADIO_BUTTON(oti.rad_use_gps), _("Use End of Route")),
2556 0, 1, 2, 3, GTK_FILL, 0, 2, 4);
2559 gtk_table_attach(GTK_TABLE(table),
2560 gtk_vseparator_new(),
2561 1, 2, 1, 3, GTK_FILL, GTK_FILL, 2,4);
2564 gtk_table_attach(GTK_TABLE(table),
2565 label = gtk_label_new(_("Category")),
2566 2, 3, 1, 2, GTK_FILL, 0, 2, 4);
2567 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
2568 gtk_table_attach(GTK_TABLE(table),
2569 cmb_category = poi_create_cat_combo(),
2570 3, 4, 1, 2, GTK_FILL, 0, 2, 4);
2573 gtk_table_attach(GTK_TABLE(table),
2574 label = gtk_label_new(_("Page")),
2575 2, 3, 2, 3, GTK_FILL, 0, 2, 4);
2576 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
2577 gtk_table_attach(GTK_TABLE(table),
2578 num_page = hildon_number_editor_new(1, 999),
2579 3, 4, 2, 3, GTK_FILL, 0, 2, 4);
2582 /* Another table for the Origin and Query. */
2583 gtk_table_attach(GTK_TABLE(table),
2584 table2 = gtk_table_new(2, 2, FALSE),
2585 0, 4, 3, 4, GTK_EXPAND | GTK_FILL, 0, 2, 4);
2588 gtk_table_attach(GTK_TABLE(table2),
2589 oti.rad_use_text = gtk_radio_button_new_with_label_from_widget(
2590 GTK_RADIO_BUTTON(oti.rad_use_gps), _("Origin")),
2591 0, 1, 0, 1, GTK_FILL, 0, 2, 4);
2592 gtk_table_attach(GTK_TABLE(table2),
2593 oti.txt_origin = gtk_entry_new(),
2594 1, 2, 0, 1, GTK_EXPAND | GTK_FILL, 0, 2, 4);
2595 gtk_entry_set_width_chars(GTK_ENTRY(oti.txt_origin), 25);
2597 g_object_set(G_OBJECT(oti.txt_origin), "hildon-input-mode",
2598 HILDON_GTK_INPUT_MODE_FULL, NULL);
2600 g_object_set(G_OBJECT(oti.txt_origin), HILDON_AUTOCAP, FALSE, NULL);
2604 gtk_table_attach(GTK_TABLE(table2),
2605 label = gtk_label_new(_("Query")),
2606 0, 1, 1, 2, GTK_FILL, 0, 2, 4);
2607 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
2608 gtk_table_attach(GTK_TABLE(table2),
2609 oti.txt_query = gtk_entry_new(),
2610 1, 2, 1, 2, GTK_EXPAND | GTK_FILL, 0, 2, 4);
2611 gtk_entry_set_width_chars(GTK_ENTRY(oti.txt_query), 25);
2613 g_object_set(G_OBJECT(oti.txt_query), "hildon-input-mode",
2614 HILDON_GTK_INPUT_MODE_FULL, NULL);
2616 g_object_set(G_OBJECT(oti.txt_query), HILDON_AUTOCAP, FALSE, NULL);
2619 /* Set up auto-completion. */
2620 origin_comp = gtk_entry_completion_new();
2621 gtk_entry_completion_set_model(origin_comp,GTK_TREE_MODEL(_loc_model));
2622 gtk_entry_completion_set_text_column(origin_comp, 0);
2623 gtk_entry_set_completion(GTK_ENTRY(oti.txt_origin), origin_comp);
2625 g_signal_connect(G_OBJECT(oti.rad_use_gps), "toggled",
2626 G_CALLBACK(origin_type_selected), &oti);
2627 g_signal_connect(G_OBJECT(oti.rad_use_route), "toggled",
2628 G_CALLBACK(origin_type_selected), &oti);
2629 g_signal_connect(G_OBJECT(oti.rad_use_text), "toggled",
2630 G_CALLBACK(origin_type_selected), &oti);
2632 g_signal_connect(G_OBJECT(cmb_category), "changed",
2633 G_CALLBACK(poi_download_cat_selected), oti.txt_query);
2636 /* Initialize fields. */
2638 hildon_number_editor_set_value(HILDON_NUMBER_EDITOR(num_page), 1);
2640 gtk_entry_set_text(GTK_ENTRY(txt_source_url), _poi_dl_url);
2648 unit2latlon(unitx, unity, lat, lon);
2650 g_ascii_formatd(strlat, 32, "%.06f", lat);
2651 g_ascii_formatd(strlon, 32, "%.06f", lon);
2652 snprintf(buffer, sizeof(buffer), "%s, %s", strlat, strlon);
2654 gtk_entry_set_text(GTK_ENTRY(oti.txt_origin), buffer);
2655 gtk_toggle_button_set_active(
2656 GTK_TOGGLE_BUTTON(oti.rad_use_text), TRUE);
2658 /* Else use "End of Route" by default if they have a route. */
2659 else if(_route.head != _route.tail)
2661 /* There is no route, so make it the default. */
2662 gtk_widget_set_sensitive(oti.rad_use_route, TRUE);
2663 gtk_toggle_button_set_active(
2664 GTK_TOGGLE_BUTTON(oti.rad_use_route), TRUE);
2665 gtk_widget_grab_focus(oti.rad_use_route);
2667 /* Else use "GPS Location" if they have GPS enabled. */
2670 /* There is no route, so desensitize "Use End of Route." */
2671 gtk_widget_set_sensitive(oti.rad_use_route, FALSE);
2674 gtk_toggle_button_set_active(
2675 GTK_TOGGLE_BUTTON(oti.rad_use_gps), TRUE);
2676 gtk_widget_grab_focus(oti.rad_use_gps);
2678 /* Else use text. */
2681 gtk_toggle_button_set_active(
2682 GTK_TOGGLE_BUTTON(oti.rad_use_text), TRUE);
2683 gtk_widget_grab_focus(oti.txt_origin);
2687 gtk_widget_show_all(dialog);
2689 while(gtk_dialog_run(GTK_DIALOG(dialog)) == GTK_RESPONSE_ACCEPT)
2691 gchar origin_buffer[BUFFER_SIZE];
2692 const gchar *source_url, *origin, *query;
2693 gchar *file_uri_str = NULL;
2694 gchar *bytes = NULL;
2696 GnomeVFSResult vfs_result;
2697 GList *poi_list = NULL;
2699 source_url = gtk_entry_get_text(GTK_ENTRY(txt_source_url));
2700 if(!strlen(source_url))
2702 popup_error(dialog, _("Please specify a source URL."));
2707 g_free(_poi_dl_url);
2708 _poi_dl_url = g_strdup(source_url);
2711 if(gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(oti.rad_use_gps)))
2715 latlon2unit(_gps.lat, _gps.lon, unitx, unity);
2716 g_ascii_formatd(strlat, 32, "%.06f", _gps.lat);
2717 g_ascii_formatd(strlon, 32, "%.06f", _gps.lon);
2718 snprintf(origin_buffer, sizeof(origin_buffer),
2719 "%s, %s", strlat, strlon);
2720 origin = origin_buffer;
2722 else if(gtk_toggle_button_get_active(
2723 GTK_TOGGLE_BUTTON(oti.rad_use_route)))
2730 /* Use last non-zero route point. */
2731 for(p = _route.tail; !p->unity; p--) { }
2735 unit2latlon(p->unitx, p->unity, lat, lon);
2736 g_ascii_formatd(strlat, 32, "%.06f", lat);
2737 g_ascii_formatd(strlon, 32, "%.06f", lon);
2738 snprintf(origin_buffer, sizeof(origin_buffer),
2739 "%s, %s", strlat, strlon);
2740 origin = origin_buffer;
2745 origin = gtk_entry_get_text(GTK_ENTRY(oti.txt_origin));
2748 porig = locate_address(dialog, origin);
2756 popup_error(dialog, _("Please specify an origin."));
2760 if(gtk_combo_box_get_active(GTK_COMBO_BOX(cmb_category)) == -1)
2762 popup_error(dialog, _("Please specify a default category."));
2766 query = gtk_entry_get_text(GTK_ENTRY(oti.txt_query));
2769 popup_error(dialog, _("Please specify a query."));
2773 /* Construct the URL. */
2775 gchar *origin_escaped;
2776 gchar *query_escaped;
2778 origin_escaped = gnome_vfs_escape_string(origin);
2779 query_escaped = gnome_vfs_escape_string(query);
2780 file_uri_str = g_strdup_printf(
2781 source_url, origin_escaped, query_escaped,
2782 hildon_number_editor_get_value(
2783 HILDON_NUMBER_EDITOR(num_page)));
2784 g_free(origin_escaped);
2785 g_free(query_escaped);
2788 /* Parse the given file as GPX. */
2789 if(GNOME_VFS_OK != (vfs_result = gnome_vfs_read_entire_file(
2790 file_uri_str, &size, &bytes)))
2792 popup_error(dialog, gnome_vfs_result_to_string(vfs_result));
2794 else if(strncmp(bytes, "<?xml", strlen("<?xml")))
2796 /* Not an XML document - must be bad locations. */
2797 popup_error(dialog, _("Invalid origin or query."));
2798 printf("bytes: %s\n", bytes);
2800 else if(gpx_poi_parse(bytes, size, &poi_list))
2802 /* Insert the POIs into the database. */
2803 gint num_inserts = poi_list_insert(dialog, poi_list,
2804 GTK_COMBO_BOX(cmb_category));
2808 /* Create a new dialog with the results. */
2809 poi_list_dialog(dialog, unitx, unity, poi_list);
2812 poi_list_free(poi_list);
2815 popup_error(dialog, _("Error parsing GPX file."));
2817 g_free(file_uri_str);
2820 /* Increment the page number for them. */
2821 hildon_number_editor_set_value(HILDON_NUMBER_EDITOR(num_page),
2822 hildon_number_editor_get_value(HILDON_NUMBER_EDITOR(num_page)) +1);
2825 /* Hide the dialog. */
2826 gtk_widget_hide(dialog);
2828 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
2833 poi_browse_dialog(gint unitx, gint unity)
2835 static GtkWidget *dialog = NULL;
2836 static GtkWidget *table = NULL;
2837 static GtkWidget *table2 = NULL;
2838 static GtkWidget *label = NULL;
2839 static GtkWidget *cmb_category = NULL;
2840 static OriginToggleInfo oti;
2841 printf("%s()\n", __PRETTY_FUNCTION__);
2845 GtkEntryCompletion *origin_comp;
2847 dialog = gtk_dialog_new_with_buttons(_("Browse POIs"),
2848 GTK_WINDOW(_window), GTK_DIALOG_MODAL,
2849 GTK_STOCK_OK, GTK_RESPONSE_ACCEPT,
2850 GTK_STOCK_CANCEL, GTK_RESPONSE_REJECT,
2853 /* Enable the help button. */
2855 hildon_help_dialog_help_enable(
2857 ossohelp_dialog_help_enable(
2859 GTK_DIALOG(dialog), HELP_ID_BROWSEPOI, _osso);
2861 gtk_box_pack_start(GTK_BOX(GTK_DIALOG(dialog)->vbox),
2862 table = gtk_table_new(3, 4, FALSE), TRUE, TRUE, 0);
2865 gtk_table_attach(GTK_TABLE(table),
2866 oti.rad_use_gps = gtk_radio_button_new_with_label(NULL,
2867 _("Use GPS Location")),
2868 0, 1, 0, 1, GTK_FILL, 0, 2, 4);
2870 /* Use End of Route. */
2871 gtk_table_attach(GTK_TABLE(table),
2872 oti.rad_use_route = gtk_radio_button_new_with_label_from_widget(
2873 GTK_RADIO_BUTTON(oti.rad_use_gps), _("Use End of Route")),
2874 0, 1, 1, 2, GTK_FILL, 0, 2, 4);
2876 gtk_table_attach(GTK_TABLE(table),
2877 gtk_vseparator_new(),
2878 1, 2, 0, 2, GTK_FILL, GTK_FILL, 2, 4);
2881 gtk_table_attach(GTK_TABLE(table),
2882 label = gtk_label_new(_("Category")),
2883 2, 3, 0, 1, GTK_FILL, 0, 2, 4);
2884 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
2885 gtk_table_attach(GTK_TABLE(table),
2886 cmb_category = poi_create_cat_combo(),
2887 3, 4, 0, 1, GTK_FILL, 0, 2, 4);
2888 /* Add an extra, "<any>" category. */
2891 GtkListStore *store = GTK_LIST_STORE(gtk_combo_box_get_model(
2892 GTK_COMBO_BOX(cmb_category)));
2893 gtk_list_store_prepend(store, &iter);
2894 gtk_list_store_set(store, &iter, 0, -1, 1, "<any>", -1);
2895 gtk_combo_box_set_active_iter(GTK_COMBO_BOX(cmb_category), &iter);
2899 /* Another table for the Origin and Query. */
2900 gtk_table_attach(GTK_TABLE(table),
2901 table2 = gtk_table_new(2, 2, FALSE),
2902 0, 4, 2, 3, GTK_EXPAND | GTK_FILL, 0, 2, 4);
2905 gtk_table_attach(GTK_TABLE(table2),
2906 oti.rad_use_text = gtk_radio_button_new_with_label_from_widget(
2907 GTK_RADIO_BUTTON(oti.rad_use_gps), _("Origin")),
2908 0, 1, 0, 1, GTK_FILL, 0, 2, 4);
2909 gtk_table_attach(GTK_TABLE(table2),
2910 oti.txt_origin = gtk_entry_new(),
2911 1, 2, 0, 1, GTK_EXPAND | GTK_FILL, 0, 2, 4);
2912 gtk_entry_set_width_chars(GTK_ENTRY(oti.txt_origin), 25);
2914 g_object_set(G_OBJECT(oti.txt_origin), "hildon-input-mode",
2915 HILDON_GTK_INPUT_MODE_FULL, NULL);
2917 g_object_set(G_OBJECT(oti.txt_origin), HILDON_AUTOCAP, FALSE, NULL);
2921 gtk_table_attach(GTK_TABLE(table2),
2922 label = gtk_label_new(_("Query")),
2923 0, 1, 1, 2, GTK_FILL, 0, 2, 4);
2924 gtk_misc_set_alignment(GTK_MISC(label), 1.f, 0.5f);
2925 gtk_table_attach(GTK_TABLE(table2),
2926 oti.txt_query = gtk_entry_new(),
2927 1, 2, 1, 2, GTK_EXPAND | GTK_FILL, 0, 2, 4);
2928 gtk_entry_set_width_chars(GTK_ENTRY(oti.txt_query), 25);
2930 g_object_set(G_OBJECT(oti.txt_query), "hildon-input-mode",
2931 HILDON_GTK_INPUT_MODE_FULL, NULL);
2933 g_object_set(G_OBJECT(oti.txt_query), HILDON_AUTOCAP, FALSE, NULL);
2936 /* Set up auto-completion. */
2937 origin_comp = gtk_entry_completion_new();
2938 gtk_entry_completion_set_model(origin_comp,GTK_TREE_MODEL(_loc_model));
2939 gtk_entry_completion_set_text_column(origin_comp, 0);
2940 gtk_entry_set_completion(GTK_ENTRY(oti.txt_origin), origin_comp);
2942 g_signal_connect(G_OBJECT(oti.rad_use_gps), "toggled",
2943 G_CALLBACK(origin_type_selected), &oti);
2944 g_signal_connect(G_OBJECT(oti.rad_use_route), "toggled",
2945 G_CALLBACK(origin_type_selected), &oti);
2946 g_signal_connect(G_OBJECT(oti.rad_use_text), "toggled",
2947 G_CALLBACK(origin_type_selected), &oti);
2950 /* Initialize fields. */
2959 unit2latlon(unitx, unity, lat, lon);
2961 g_ascii_formatd(strlat, 32, "%.06f", lat);
2962 g_ascii_formatd(strlon, 32, "%.06f", lon);
2963 snprintf(buffer, sizeof(buffer), "%s, %s", strlat, strlon);
2965 gtk_entry_set_text(GTK_ENTRY(oti.txt_origin), buffer);
2966 gtk_toggle_button_set_active(
2967 GTK_TOGGLE_BUTTON(oti.rad_use_text), TRUE);
2969 /* Else use "End of Route" by default if they have a route. */
2970 else if(_route.head != _route.tail)
2972 /* There is no route, so make it the default. */
2973 gtk_widget_set_sensitive(oti.rad_use_route, TRUE);
2974 gtk_toggle_button_set_active(
2975 GTK_TOGGLE_BUTTON(oti.rad_use_route), TRUE);
2976 gtk_widget_grab_focus(oti.rad_use_route);
2978 /* Else use "GPS Location" if they have GPS enabled. */
2981 /* There is no route, so desensitize "Use End of Route." */
2982 gtk_widget_set_sensitive(oti.rad_use_route, FALSE);
2985 gtk_toggle_button_set_active(
2986 GTK_TOGGLE_BUTTON(oti.rad_use_gps), TRUE);
2987 gtk_widget_grab_focus(oti.rad_use_gps);
2989 /* Else use text. */
2992 gtk_toggle_button_set_active(
2993 GTK_TOGGLE_BUTTON(oti.rad_use_text), TRUE);
2994 gtk_widget_grab_focus(oti.txt_origin);
2998 gtk_widget_show_all(dialog);
3000 while(gtk_dialog_run(GTK_DIALOG(dialog)) ==GTK_RESPONSE_ACCEPT)
3002 gchar buffer[BUFFER_SIZE];
3003 const gchar *origin, *query;
3005 GList *poi_list = NULL;
3007 gboolean is_cat = FALSE;
3010 if(gtk_toggle_button_get_active(GTK_TOGGLE_BUTTON(oti.rad_use_gps)))
3014 latlon2unit(_gps.lat, _gps.lon, unitx, unity);
3015 g_ascii_formatd(strlat, 32, "%.06f", _gps.lat);
3016 g_ascii_formatd(strlon, 32, "%.06f", _gps.lon);
3017 snprintf(buffer, sizeof(buffer), "%s, %s", strlat, strlon);
3020 else if(gtk_toggle_button_get_active(
3021 GTK_TOGGLE_BUTTON(oti.rad_use_route)))
3028 /* Use last non-zero route point. */
3029 for(p = _route.tail; !p->unity; p--) { }
3033 unit2latlon(p->unitx, p->unity, lat, lon);
3034 g_ascii_formatd(strlat, 32, "%.06f", lat);
3035 g_ascii_formatd(strlon, 32, "%.06f", lon);
3036 snprintf(buffer, sizeof(buffer), "%s, %s", strlat, strlon);
3042 origin = gtk_entry_get_text(GTK_ENTRY(oti.txt_origin));
3043 porig = locate_address(dialog, origin);
3050 popup_error(dialog, _("Please specify an origin."));
3054 /* Check if we're doing a category search. */
3057 if(gtk_combo_box_get_active_iter(
3058 GTK_COMBO_BOX(cmb_category), &iter))
3061 gtk_combo_box_get_model(GTK_COMBO_BOX(cmb_category)),
3062 &iter, 0, &cat_id, -1);
3070 query = g_strdup_printf("%%%s%%",
3071 gtk_entry_get_text(GTK_ENTRY(oti.txt_query)));
3073 unit2latlon(unitx, unity, lat, lon);
3077 if(SQLITE_OK != sqlite3_bind_int(_stmt_browsecat_poi, 1, cat_id) ||
3078 SQLITE_OK != sqlite3_bind_text(_stmt_browsecat_poi, 2, query,
3080 SQLITE_OK != sqlite3_bind_double(_stmt_browsecat_poi, 3, lat) ||
3081 SQLITE_OK != sqlite3_bind_double(_stmt_browsecat_poi, 4, lon))
3083 g_printerr("Failed to bind values for _stmt_browsecat_poi\n");
3086 stmt = _stmt_browsecat_poi;
3090 if(SQLITE_OK != sqlite3_bind_text(_stmt_browse_poi, 1, query,
3092 SQLITE_OK != sqlite3_bind_double(_stmt_browse_poi, 2, lat) ||
3093 SQLITE_OK != sqlite3_bind_double(_stmt_browse_poi, 3, lon))
3095 g_printerr("Failed to bind values for _stmt_browse_poi\n");
3098 stmt = _stmt_browse_poi;
3101 while(SQLITE_ROW == sqlite3_step(stmt))
3103 PoiInfo *poi = g_slice_new(PoiInfo);
3104 poi->poi_id = sqlite3_column_int(stmt, 0);
3105 poi->cat_id = sqlite3_column_int(stmt, 1);
3106 poi->lat = sqlite3_column_double(stmt, 2);
3107 poi->lon = sqlite3_column_double(stmt, 3);
3108 poi->label =g_strdup(sqlite3_column_text(stmt, 4));
3109 poi->desc = g_strdup(sqlite3_column_text(stmt, 5));
3110 poi->clabel=g_strdup(sqlite3_column_text(stmt, 6));
3111 poi_list = g_list_prepend(poi_list, poi);
3113 sqlite3_reset(stmt);
3117 /* Create a new dialog with the results. */
3118 poi_list_dialog(dialog, unitx, unity, poi_list);
3119 poi_list_free(poi_list);
3122 popup_error(dialog, _("No POIs found."));
3127 /* Hide the dialog. */
3128 gtk_widget_hide(dialog);
3130 vprintf("%s(): return TRUE\n", __PRETTY_FUNCTION__);
3135 * Render all the POI data. This should be done before rendering track data.
3141 gdouble lat1, lat2, lon1, lon2;
3144 GdkPixbuf *pixbuf = NULL;
3145 GError *error = NULL;
3146 printf("%s()\n", __PRETTY_FUNCTION__);
3148 if(_poi_db && _poi_zoom > _zoom)
3150 gint diag_offset = pixel2unit(MAX(_view_width_pixels,
3151 _view_height_pixels) / 2);
3152 buf2unit(0, _view_height_pixels, unitx, unity);
3153 unitx = _center.unitx - diag_offset;
3154 unity = _center.unity + diag_offset;
3155 unit2latlon(unitx, unity, lat1, lon1);
3156 unitx = _center.unitx + diag_offset;
3157 unity = _center.unity - diag_offset;
3158 unit2latlon(unitx, unity, lat2, lon2);
3160 if(SQLITE_OK != sqlite3_bind_double(_stmt_select_poi, 1, lat1) ||
3161 SQLITE_OK != sqlite3_bind_double(_stmt_select_poi, 2, lat2) ||
3162 SQLITE_OK != sqlite3_bind_double(_stmt_select_poi, 3, lon1) ||
3163 SQLITE_OK != sqlite3_bind_double(_stmt_select_poi, 4, lon2))
3165 g_printerr("Failed to bind values for _stmt_select_poi\n");
3169 while(SQLITE_ROW == sqlite3_step(_stmt_select_poi))
3171 lat1 = sqlite3_column_double(_stmt_select_poi, 0);
3172 lon1 = sqlite3_column_double(_stmt_select_poi, 1);
3173 gchar *poi_label = g_utf8_strdown(sqlite3_column_text(
3174 _stmt_select_poi, 3), -1);
3175 gchar *cat_label = g_utf8_strdown(sqlite3_column_text(
3176 _stmt_select_poi, 6), -1);
3178 latlon2unit(lat1, lon1, unitx, unity);
3179 unit2buf(unitx, unity, poix, poiy);
3181 /* Try to get icon for specific POI first. */
3182 snprintf(buffer, sizeof(buffer), "%s/%s.jpg",
3183 _poi_db_dirname, poi_label);
3184 pixbuf = gdk_pixbuf_new_from_file(buffer, &error);
3187 /* No icon for specific POI - try for category. */
3189 snprintf(buffer, sizeof(buffer), "%s/%s.jpg",
3190 _poi_db_dirname, cat_label);
3191 pixbuf = gdk_pixbuf_new_from_file(buffer, &error);
3195 /* No icon for POI or for category.
3196 * Try default POI icon file. */
3198 snprintf(buffer, sizeof(buffer), "%s/poi.jpg",
3200 pixbuf = gdk_pixbuf_new_from_file(buffer, &error);
3204 /* No icon for POI or for category or default POI icon file.
3205 Draw default purple square. */
3207 gdk_draw_rectangle(_map_pixmap, _gc[COLORABLE_POI], TRUE,
3208 poix - (gint)(1.5f * _draw_width),
3209 poiy - (gint)(1.5f * _draw_width),
3215 /* We found an icon to draw. */
3221 poix - gdk_pixbuf_get_width(pixbuf) / 2,
3222 poiy - gdk_pixbuf_get_height(pixbuf) / 2,
3224 GDK_RGB_DITHER_NONE, 0, 0);
3225 g_object_unref(pixbuf);
3231 sqlite3_reset(_stmt_select_poi);
3234 vprintf("%s(): return\n", __PRETTY_FUNCTION__);
3240 printf("%s()\n", __PRETTY_FUNCTION__);
3244 sqlite3_close(_poi_db);
3248 vprintf("%s(): return\n", __PRETTY_FUNCTION__);