+// plugins
+
+/*****************
+ * Setup helpers *
+ *****************/
+static void combo_sensitive(GtkCellLayout *cell_layout, GtkCellRenderer *cell,
+ GtkTreeModel *tree_model, GtkTreeIter *iter, gpointer data)
+{
+ gboolean sensitive = !gtk_tree_model_iter_has_child(tree_model, iter);
+ g_object_set(cell, "sensitive", sensitive, NULL);
+}
+
+static void site_setup(AWeatherGui *self)
+{
+ GtkTreeIter state, city;
+ GtkTreeStore *store = GTK_TREE_STORE(aweather_gui_get_object(self, "sites"));
+ for (int i = 0; cities[i].label; i++) {
+ if (cities[i].type == LOCATION_STATE) {
+ gtk_tree_store_append(store, &state, NULL);
+ gtk_tree_store_set (store, &state, 0, cities[i].label,
+ 1, cities[i].code, -1);
+ } else {
+ gtk_tree_store_append(store, &city, &state);
+ gtk_tree_store_set (store, &city, 0, cities[i].label,
+ 1, cities[i].code, -1);
+ }
+ }
+
+ GtkWidget *combo = aweather_gui_get_widget(self, "site");
+ GObject *renderer = aweather_gui_get_object(self, "site_rend");
+ gtk_cell_layout_set_cell_data_func(GTK_CELL_LAYOUT(combo),
+ GTK_CELL_RENDERER(renderer), combo_sensitive, NULL, NULL);
+
+ g_signal_connect(self->view, "site-changed",
+ G_CALLBACK(update_site_widget), self);
+}
+
+static void time_setup(AWeatherGui *self)
+{
+ GtkTreeView *tview = GTK_TREE_VIEW(aweather_gui_get_widget(self, "time"));
+ GtkCellRenderer *rend = gtk_cell_renderer_text_new();
+ GtkTreeViewColumn *col = gtk_tree_view_column_new_with_attributes(
+ "Time", rend, "text", 0, NULL);
+
+ gtk_tree_view_append_column(tview, col);
+ g_object_set(rend, "size-points", 8.0, NULL);
+
+ g_signal_connect(self->view, "time-changed",
+ G_CALLBACK(update_time_widget), self);
+}
+
+
+/*************************
+ * Deprecated site stuff *
+ *************************/
+/* TODO: These update times functions are getting ugly... */
+static void update_times_gtk(AWeatherGui *self, GList *times)
+{
+ gchar *last_time = NULL;
+ GRegex *regex = g_regex_new("^[A-Z]{4}_([0-9]{8}_[0-9]{4})$", 0, 0, NULL); // KLSX_20090622_2113
+ GMatchInfo *info;
+
+ GtkTreeView *tview = GTK_TREE_VIEW(aweather_gui_get_widget(self, "time"));
+ GtkListStore *lstore = GTK_LIST_STORE(gtk_tree_view_get_model(tview));
+ gtk_list_store_clear(lstore);
+ GtkTreeIter iter;
+ times = g_list_reverse(times);
+ for (GList *cur = times; cur; cur = cur->next) {
+ g_message("trying time %s", (gchar*)cur->data);
+ if (g_regex_match(regex, cur->data, 0, &info)) {
+ gchar *time = g_match_info_fetch(info, 1);
+ g_message("adding time %s", (gchar*)cur->data);
+ gtk_list_store_insert(lstore, &iter, 0);
+ gtk_list_store_set(lstore, &iter, 0, time, -1);
+ last_time = time;
+ }
+ }
+
+ gis_view_set_time(self->view, last_time);
+
+ g_regex_unref(regex);
+ g_list_foreach(times, (GFunc)g_free, NULL);
+ g_list_free(times);
+}
+static void update_times_online_cb(char *path, gboolean updated, gpointer _self)
+{
+ GList *times = NULL;
+ gchar *data;
+ gsize length;
+ g_file_get_contents(path, &data, &length, NULL);
+ gchar **lines = g_strsplit(data, "\n", -1);
+ for (int i = 0; lines[i] && lines[i][0]; i++) {
+ char **parts = g_strsplit(lines[i], " ", 2);
+ times = g_list_prepend(times, g_strdup(parts[1]));
+ g_strfreev(parts);
+ }
+ g_strfreev(lines);
+ g_free(data);
+
+ update_times_gtk(_self, times);
+}
+static void update_times(AWeatherGui *self, GisView *view, char *site)
+{
+ if (gis_world_get_offline(self->world)) {
+ GList *times = NULL;
+ gchar *path = g_build_filename(g_get_user_cache_dir(), PACKAGE, "nexrd2", "raw", site, NULL);
+ GDir *dir = g_dir_open(path, 0, NULL);
+ if (dir) {
+ const gchar *name;
+ while ((name = g_dir_read_name(dir))) {
+ times = g_list_prepend(times, g_strdup(name));
+ }
+ g_dir_close(dir);
+ }
+ g_free(path);
+ update_times_gtk(self, times);
+ } else {
+ gchar *path = g_strdup_printf("nexrd2/raw/%s/dir.list", site);
+ char *base = gis_prefs_get_string(self->prefs, "general/nexrad_url");
+ cache_file(base, path, AWEATHER_REFRESH, NULL, update_times_online_cb, self);
+ /* update_times_gtk from update_times_online_cb */
+ }
+}
+static void on_gis_site_changed(GisView *view, char *site, gpointer _self)
+{
+ AWeatherGui *self = AWEATHER_GUI(_self);
+ g_debug("GisPluginRadar: on_site_changed - Loading wsr88d list for %s", site);
+ update_times(self, view, site);
+}
+static void on_gis_refresh(GisWorld *world, gpointer _self)
+{
+ AWeatherGui *self = AWEATHER_GUI(_self);
+ char *site = gis_view_get_site(self->view);
+ update_times(self, self->view, site);
+}