/* * evolution-cal-config-weather.c * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2 of the License, or (at your option) version 3. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with the program; if not, see * */ #include #include #include #define GWEATHER_I_KNOW_THIS_IS_UNSTABLE #include #undef GWEATHER_I_KNOW_THIS_IS_UNSTABLE #include #include "e-source-weather.h" typedef ESourceConfigBackend ECalConfigWeather; typedef ESourceConfigBackendClass ECalConfigWeatherClass; /* Module Entry Points */ void e_module_load (GTypeModule *type_module); void e_module_unload (GTypeModule *type_module); typedef struct _Context Context; struct _Context { GtkWidget *location_entry; }; /* Forward Declarations */ GType e_cal_config_weather_get_type (void); G_DEFINE_DYNAMIC_TYPE ( ECalConfigWeather, e_cal_config_weather, E_TYPE_SOURCE_CONFIG_BACKEND) static void cal_config_weather_context_free (Context *context) { g_object_unref (context->location_entry); g_slice_free (Context, context); } static gboolean cal_config_weather_location_to_string (GBinding *binding, const GValue *source_value, GValue *target_value, gpointer user_data) { GWeatherLocation *location; gchar *string = NULL; location = g_value_get_boxed (source_value); if (location != NULL) { const gchar *code; gchar *city_name; code = gweather_location_get_code (location); city_name = gweather_location_get_city_name (location); string = g_strdup_printf ("%s/%s", code, city_name); g_free (city_name); } g_value_take_string (target_value, string); return TRUE; } static gboolean cal_config_weather_string_to_location (GBinding *binding, const GValue *source_value, GValue *target_value, gpointer user_data) { GWeatherLocation *world; GWeatherLocation *match, *start; const gchar *string; const gchar *city_name; const gchar *code; gchar **tokens; world = user_data; string = g_value_get_string (source_value); if (string == NULL) return FALSE; /* String is: STATION-CODE '/' CITY-NAME */ tokens = g_strsplit (string, "/", 2); if (g_strv_length (tokens) != 2) { g_strfreev (tokens); return FALSE; } code = tokens[0]; city_name = tokens[1]; match = start = gweather_location_find_by_station_code (world, code); while (match) { gchar *cmp_city_name; /* Does the city name match? */ cmp_city_name = gweather_location_get_city_name (match); if (g_strcmp0 (city_name, cmp_city_name) == 0) { g_free (cmp_city_name); break; } g_free (cmp_city_name); /* No match, try parent */ match = gweather_location_get_parent (match); } if (match == NULL) { /* No exact match, use start instead */ match = start; } g_value_set_boxed (target_value, match); g_strfreev (tokens); return TRUE; } static gboolean cal_config_weather_allow_creation (ESourceConfigBackend *backend) { ESourceConfig *config; ECalSourceConfig *cal_config; ECalClientSourceType source_type; /* No such thing as weather task lists or weather memo lists. */ config = e_source_config_backend_get_config (backend); cal_config = E_CAL_SOURCE_CONFIG (config); source_type = e_cal_source_config_get_source_type (cal_config); return (source_type == E_CAL_CLIENT_SOURCE_TYPE_EVENTS); } static void cal_config_weather_insert_widgets (ESourceConfigBackend *backend, ESource *scratch_source) { ESourceConfig *config; ESourceExtension *extension; GWeatherLocation *world; GtkWidget *widget; Context *context; const gchar *extension_name; const gchar *uid; context = g_slice_new (Context); uid = e_source_get_uid (scratch_source); config = e_source_config_backend_get_config (backend); g_object_set_data_full ( G_OBJECT (backend), uid, context, (GDestroyNotify) cal_config_weather_context_free); world = gweather_location_new_world (TRUE); e_cal_source_config_add_offline_toggle ( E_CAL_SOURCE_CONFIG (config), scratch_source); widget = gweather_location_entry_new (world); e_source_config_insert_widget ( config, scratch_source, _("Location:"), widget); context->location_entry = g_object_ref (widget); gtk_widget_show (widget); e_source_config_add_refresh_interval (config, scratch_source); extension_name = E_SOURCE_EXTENSION_WEATHER_BACKEND; extension = e_source_get_extension (scratch_source, extension_name); g_object_bind_property_full ( extension, "location", context->location_entry, "location", G_BINDING_BIDIRECTIONAL | G_BINDING_SYNC_CREATE, cal_config_weather_string_to_location, cal_config_weather_location_to_string, gweather_location_ref (world), (GDestroyNotify) gweather_location_unref); gweather_location_unref (world); } static gboolean cal_config_weather_check_complete (ESourceConfigBackend *backend, ESource *scratch_source) { ESourceWeather *extension; const gchar *extension_name; const gchar *location; extension_name = E_SOURCE_EXTENSION_WEATHER_BACKEND; extension = e_source_get_extension (scratch_source, extension_name); location = e_source_weather_get_location (extension); g_debug ("Location: [%s]", location); return (location != NULL) && (*location != '\0'); } static void e_cal_config_weather_class_init (ESourceConfigBackendClass *class) { EExtensionClass *extension_class; extension_class = E_EXTENSION_CLASS (class); extension_class->extensible_type = E_TYPE_CAL_SOURCE_CONFIG; class->parent_uid = "weather-stub"; class->backend_name = "weather"; class->allow_creation = cal_config_weather_allow_creation; class->insert_widgets = cal_config_weather_insert_widgets; class->check_complete = cal_config_weather_check_complete; } static void e_cal_config_weather_class_finalize (ESourceConfigBackendClass *class) { } static void e_cal_config_weather_init (ESourceConfigBackend *backend) { } G_MODULE_EXPORT void e_module_load (GTypeModule *type_module) { e_source_weather_type_register (type_module); e_cal_config_weather_register_type (type_module); } G_MODULE_EXPORT void e_module_unload (GTypeModule *type_module) { }