1 /* This file is part of Beifahrer.
3 * Copyright (C) 2010 Philipp Zabel
5 * Beifahrer is free software: you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation, either version 3 of the License, or
8 * (at your option) any later version.
10 * Beifahrer is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
15 * You should have received a copy of the GNU General Public License
16 * along with Beifahrer. If not, see <http://www.gnu.org/licenses/>.
22 public class QueryWindow : StackableWindow {
23 public const string GCONF_KEY_ARRIVAL = "/apps/beifahrer/arrival";
24 public const string GCONF_KEY_DEPARTURE = "/apps/beifahrer/departure";
25 public const string GCONF_KEY_USE_LOCATION = "/apps/beifahrer/use_location";
28 CityButton departure_button;
29 CityButton arrival_button;
31 TouchSelector tolerance_selector;
32 Location.GPSDControl control;
33 Location.GPSDevice device;
35 bool use_location = true;
39 set_title ("Beifahrer");
41 var menu = new AppMenu ();
42 var settings = new Gtk.Button.with_label (_("Settings"));
44 menu.append (settings);
47 adac = new AdacMitfahrclub ();
48 gconf = GConf.Client.get_default ();
50 tolerance_selector = new TouchSelector.text ();
51 for (int days = 0; days <= 4; days += 1)
52 tolerance_selector.append_text (_("+/- %d days").printf (days));
54 var alignment = new Alignment (0.0f, 0.0f, 1.0f, 1.0f);
55 alignment.top_padding = MARGIN_HALF;
56 alignment.left_padding = MARGIN_DOUBLE;
57 alignment.right_padding = MARGIN_DOUBLE;
58 var table = new Table (5, 2, false);
60 departure_button = new CityButton (SizeType.FINGER_HEIGHT,
61 ButtonArrangement.VERTICAL, adac.get_city_list ());
62 departure_button.set_title (_("Departure"));
63 departure_button.set_value (_("Please select"));
64 departure_button.set_alignment (0.0f, 0.0f, 0.5f, 0.5f);
65 table.attach (departure_button, 0, 2, 0, 1, AttachOptions.FILL | AttachOptions.EXPAND, AttachOptions.FILL, 0, 0);
68 departure_button.set_active (gconf.get_int ("/apps/beifahrer/departure"));
72 arrival_button = new CityButton (SizeType.FINGER_HEIGHT,
73 ButtonArrangement.VERTICAL, adac.get_city_list ());
74 arrival_button.set_title (_("Arrival"));
75 arrival_button.set_value (_("Please select"));
76 arrival_button.set_alignment (0.0f, 0.0f, 0.5f, 0.5f);
77 table.attach (arrival_button, 0, 2, 1, 2, AttachOptions.FILL | AttachOptions.EXPAND, AttachOptions.FILL, 0, 0);
80 arrival_button.set_active (gconf.get_int ("/apps/beifahrer/arrival"));
84 var switch_button = new Gtk.Button.with_label (_("Switch departure and arrival"));
85 Hildon.gtk_widget_set_theme_size (switch_button, SizeType.FINGER_HEIGHT);
86 switch_button.set_alignment (0.0f, 0.5f);
87 table.attach (switch_button, 0, 2, 2, 3, AttachOptions.FILL, AttachOptions.FILL, 0, 0);
89 date = new DateButton (SizeType.FINGER_HEIGHT,
90 ButtonArrangement.VERTICAL);
91 date.set_alignment (0.0f, 0.0f, 0.5f, 0.5f);
92 table.attach (date, 0, 1, 3, 4, AttachOptions.FILL | AttachOptions.EXPAND, AttachOptions.FILL, 0, 0);
94 var button = new PickerButton (SizeType.FINGER_HEIGHT,
95 ButtonArrangement.VERTICAL);
96 button.set_selector (tolerance_selector);
97 button.set_title (_("Tolerance"));
98 button.set_value (_("+/- 0 days"));
99 button.set_alignment (0.0f, 0.0f, 0.5f, 0.5f);
100 table.attach (button, 1, 2, 3, 4, AttachOptions.FILL, AttachOptions.FILL, 0, 0);
102 var search_button = new Gtk.Button.with_label (_("Search"));
103 Hildon.gtk_widget_set_theme_size (search_button, SizeType.FINGER_HEIGHT);
104 table.attach (search_button, 0, 2, 4, 5, AttachOptions.FILL, AttachOptions.FILL, 0, 0);
106 alignment.add (table);
109 switch_button.clicked.connect (on_switch_button_clicked);
110 search_button.clicked.connect (on_search_button_clicked);
111 settings.clicked.connect (on_settings_clicked);
115 control = Location.GPSDControl.get_default ();
116 control.preferred_method = Location.METHOD_ACWP;
117 control.preferred_interval = Location.GPSDControlInterval.@1S;
118 control.error.connect (() => { print ("control error\n"); });
119 control.error_verbose.connect ((e) => {
121 case Location.GPSDControlError.USER_REJECTED_DIALOG:
122 print ("\tuser rejected dialog\n");
124 case Location.GPSDControlError.USER_REJECTED_SETTINGS:
125 print ("\tuser rejected settings\n");
127 case Location.GPSDControlError.BT_GPS_NOT_AVAILABLE:
128 print ("\tbt gps not available\n");
130 case Location.GPSDControlError.METHOD_NOT_ALLOWED_IN_OFFLINE_MODE:
131 print ("\tmethod not allowed in offline mode\n");
133 case Location.GPSDControlError.SYSTEM:
134 Banner.show_information (this, null, _("No GPS available!"));
138 control.gpsd_running.connect (() => { print ("control running\n"); });
139 control.gpsd_stopped.connect (() => { print ("control stopped\n"); });
142 use_location = gconf.get_bool (GCONF_KEY_USE_LOCATION);
145 want_location = use_location;
149 device = (Location.GPSDevice) GLib.Object.@new (typeof (Location.GPSDevice), null);
150 device.changed.connect (on_location_changed);
151 device.connected.connect (() => { print ("device connected\n"); });
152 device.disconnected.connect (() => { print ("device disconnected\n"); });
154 // In case the device already has a fix:
155 on_location_changed ();
158 void on_location_changed () requires (device.fix != null) {
159 if (!want_location || device.status == Location.GPSDeviceStatus.NO_FIX)
162 if (Location.GPS_DEVICE_LATLONG_SET in (int) device.fix.fields) {
163 print ("fix: lat=%f, lon=%f\n", device.fix.latitude, device.fix.longitude);
165 unowned City city = adac.find_nearest_city (device.fix.latitude, device.fix.longitude);
167 int n = adac.get_city_list ().index (city);
168 int n_from = departure_button.get_active ();
169 int n_to = arrival_button.get_active ();
171 print ("city(%d): %s (%d)\n", n, city.name, city.number);
174 departure_button.set_active (n);
176 // If we are at the previous point of arrival, prepare for return trip
178 arrival_button.set_active (n_from);
183 want_location = false;
187 void on_search_button_clicked (Gtk.Button button) {
190 n = departure_button.get_active ();
193 string city_from = adac.get_city_list ().nth_data (n).name;
195 if (gconf.get_int (GCONF_KEY_DEPARTURE) != n)
196 gconf.set_int (GCONF_KEY_DEPARTURE, n);
200 n = arrival_button.get_active ();
203 string city_to = adac.get_city_list ().nth_data (n).name;
205 if (gconf.get_int (GCONF_KEY_ARRIVAL) != n)
206 gconf.set_int (GCONF_KEY_ARRIVAL, n);
210 uint year, month, day;
211 date.get_date (out year, out month, out day);
213 date.set_day ((DateDay) day);
214 date.set_month ((DateMonth) (month + DateMonth.JANUARY));
215 date.set_year ((DateYear) year);
217 int tolerance = tolerance_selector.get_active (0);
219 var window = new LiftListWindow (adac);
221 window.find_lifts.begin (city_from, departure_button.get_radius (), city_to, arrival_button.get_radius (), date, tolerance);
224 // Switch departure and arrival
225 void on_switch_button_clicked () {
226 int n = departure_button.get_active ();
227 departure_button.set_active (arrival_button.get_active ());
228 arrival_button.set_active (n);
229 n = departure_button.get_radius ();
230 departure_button.set_radius (arrival_button.get_radius ());
231 arrival_button.set_radius (n);
234 void on_settings_clicked () {
235 var dialog = new SettingsDialog (this);
236 dialog.response.connect (on_settings_response);
240 void on_settings_response (int response_id) {
241 bool old_use_location = use_location;
242 use_location = gconf.get_bool (GCONF_KEY_USE_LOCATION);
243 if (!old_use_location && use_location) {
244 want_location = true;