Created chart editing tab, making it the default

This commit is contained in:
Gergely Polonkai 2013-09-09 11:22:21 +02:00
parent 23d3d2203e
commit 4f62c07dc0
2 changed files with 126 additions and 2 deletions

View File

@ -1,4 +1,5 @@
#include <string.h> #include <string.h>
#include <glib/gi18n.h>
#include <libgd/gd.h> #include <libgd/gd.h>
#include "ag-app.h" #include "ag-app.h"
@ -8,11 +9,25 @@ struct _AgWindowPrivate {
GtkWidget *grid; GtkWidget *grid;
GtkWidget *header_bar; GtkWidget *header_bar;
GtkWidget *notebook; GtkWidget *notebook;
GtkWidget *name;
GtkWidget *north_lat;
GtkWidget *south_lat;
GtkWidget *latitude;
GtkWidget *east_long;
GtkWidget *west_long;
GtkWidget *longitude;
GtkWidget *year;
GtkWidget *month;
GtkWidget *day;
GtkWidget *hour;
GtkWidget *minute;
GtkWidget *second;
GtkBuilder *builder; GtkBuilder *builder;
gint tab_chart; gint tab_chart;
gint tab_aspects; gint tab_aspects;
gint tab_points; gint tab_points;
gint tab_edit;
}; };
G_DEFINE_TYPE(AgWindow, ag_window, GTK_TYPE_APPLICATION_WINDOW); G_DEFINE_TYPE(AgWindow, ag_window, GTK_TYPE_APPLICATION_WINDOW);
@ -54,6 +69,8 @@ set_tab_cb(GSimpleAction *action, GVariant *parameter, gpointer user_data)
target_tab = window->priv->tab_aspects; target_tab = window->priv->tab_aspects;
} else if (strcmp(target, "points") == 0) { } else if (strcmp(target, "points") == 0) {
target_tab = window->priv->tab_points; target_tab = window->priv->tab_points;
} else if (strcmp(target, "edit") == 0) {
target_tab = window->priv->tab_edit;
} else { } else {
g_warning("Unknown tab!"); g_warning("Unknown tab!");
@ -72,7 +89,7 @@ change_tab_cb(GSimpleAction *action, GVariant *state, gpointer user_data)
static GActionEntry win_entries[] = { static GActionEntry win_entries[] = {
{ "close", close_cb, NULL, NULL, NULL }, { "close", close_cb, NULL, NULL, NULL },
{ "gear-menu", gear_menu_cb, NULL, "false", NULL }, { "gear-menu", gear_menu_cb, NULL, "false", NULL },
{ "tab-change", set_tab_cb, "s", "'chart'", change_tab_cb }, { "tab-change", set_tab_cb, "s", "'edit'", change_tab_cb },
}; };
static void static void
@ -110,6 +127,101 @@ ag_window_class_init(AgWindowClass *klass)
g_type_class_add_private(klass, sizeof(AgWindowPrivate)); g_type_class_add_private(klass, sizeof(AgWindowPrivate));
} }
static GtkWidget *
notebook_edit(AgWindow *window)
{
GtkWidget *grid;
GtkWidget *label;
AgWindowPrivate *priv = window->priv;
grid = gtk_grid_new();
label = gtk_label_new(_("Name"));
gtk_grid_attach(GTK_GRID(grid), label, 0, 0, 1, 1);
priv->name = gtk_entry_new();
gtk_grid_attach(GTK_GRID(grid), priv->name, 1, 0, 6, 1);
label = gtk_label_new(_("Country"));
gtk_grid_attach(GTK_GRID(grid), label, 0, 1, 1, 1);
label = gtk_label_new(_("City"));
gtk_grid_attach(GTK_GRID(grid), label, 0, 2, 1, 1);
label = gtk_label_new(_("Latitude"));
gtk_grid_attach(GTK_GRID(grid), label, 0, 3, 2, 1);
priv->north_lat = gtk_radio_button_new_with_label(NULL, _("North"));
gtk_grid_attach(GTK_GRID(grid), priv->north_lat, 0, 4, 1, 1);
priv->south_lat = gtk_radio_button_new_with_label_from_widget(GTK_RADIO_BUTTON(priv->north_lat), _("South"));
gtk_grid_attach(GTK_GRID(grid), priv->south_lat, 1, 4, 1, 1);
priv->latitude = gtk_spin_button_new_with_range(0.0, 90.0, 0.1);
gtk_spin_button_set_digits(GTK_SPIN_BUTTON(priv->latitude), 6);
gtk_grid_attach(GTK_GRID(grid), priv->latitude, 0, 5, 2, 1);
label = gtk_label_new(_("Longitude"));
gtk_grid_attach(GTK_GRID(grid), label, 2, 3, 2, 1);
priv->east_long = gtk_radio_button_new_with_label(NULL, _("East"));
gtk_grid_attach(GTK_GRID(grid), priv->east_long, 2, 4, 1, 1);
priv->west_long = gtk_radio_button_new_with_label_from_widget(GTK_RADIO_BUTTON(priv->east_long), _("West"));
gtk_grid_attach(GTK_GRID(grid), priv->west_long, 3, 4, 1, 1);
priv->longitude = gtk_spin_button_new_with_range(0.0, 180.0, 0.1);
gtk_spin_button_set_digits(GTK_SPIN_BUTTON(priv->longitude), 6);
gtk_grid_attach(GTK_GRID(grid), priv->longitude, 2, 5, 2, 1);
label = gtk_label_new(_("Year"));
gtk_grid_attach(GTK_GRID(grid), label, 4, 1, 1, 1);
priv->year = gtk_spin_button_new_with_range(G_MININT, G_MAXINT, 1);
gtk_spin_button_set_digits(GTK_SPIN_BUTTON(priv->year), 0);
gtk_spin_button_set_value(GTK_SPIN_BUTTON(priv->year), 0);
gtk_grid_attach(GTK_GRID(grid), priv->year, 4, 2, 1, 1);
label = gtk_label_new(_("Month"));
gtk_grid_attach(GTK_GRID(grid), label, 5, 1, 1, 1);
priv->month = gtk_spin_button_new_with_range(1, 12, 1);
gtk_spin_button_set_digits(GTK_SPIN_BUTTON(priv->month), 0);
gtk_grid_attach(GTK_GRID(grid), priv->month, 5, 2, 1, 1);
label = gtk_label_new(_("Day"));
gtk_grid_attach(GTK_GRID(grid), label, 6, 1, 1, 1);
priv->day = gtk_spin_button_new_with_range(1, 31, 1);
gtk_spin_button_set_digits(GTK_SPIN_BUTTON(priv->day), 0);
gtk_grid_attach(GTK_GRID(grid), priv->day, 6, 2, 1, 1);
label = gtk_label_new(_("Hour"));
gtk_grid_attach(GTK_GRID(grid), label, 4, 3, 1, 1);
priv->hour = gtk_spin_button_new_with_range(0, 23, 1);
gtk_spin_button_set_digits(GTK_SPIN_BUTTON(priv->hour), 0);
gtk_grid_attach(GTK_GRID(grid), priv->hour, 4, 4, 1, 1);
label = gtk_label_new(_("Minute"));
gtk_grid_attach(GTK_GRID(grid), label, 5, 3, 1, 1);
priv->minute = gtk_spin_button_new_with_range(0, 59, 1);
gtk_spin_button_set_digits(GTK_SPIN_BUTTON(priv->minute), 0);
gtk_grid_attach(GTK_GRID(grid), priv->minute, 5, 4, 1, 1);
label = gtk_label_new(_("Second"));
gtk_grid_attach(GTK_GRID(grid), label, 6, 3, 1, 1);
priv->second = gtk_spin_button_new_with_range(0, 61, 1);
gtk_spin_button_set_digits(GTK_SPIN_BUTTON(priv->second), 0);
gtk_grid_attach(GTK_GRID(grid), priv->second, 6, 4, 1, 1);
gtk_widget_show_all(grid);
return grid;
}
static void static void
window_populate(AgWindow *window) window_populate(AgWindow *window)
{ {
@ -117,6 +229,7 @@ window_populate(AgWindow *window)
GtkWidget *menu_button; GtkWidget *menu_button;
GObject *menu; GObject *menu;
GtkWidget *placeholder; GtkWidget *placeholder;
GtkWidget *tab;
priv->header_bar = gd_header_bar_new(); priv->header_bar = gd_header_bar_new();
menu_button = gd_header_menu_button_new(); menu_button = gd_header_menu_button_new();
@ -131,8 +244,12 @@ window_populate(AgWindow *window)
gtk_menu_button_set_menu_model(GTK_MENU_BUTTON(menu_button), G_MENU_MODEL(menu)); gtk_menu_button_set_menu_model(GTK_MENU_BUTTON(menu_button), G_MENU_MODEL(menu));
priv->notebook = gtk_notebook_new(); priv->notebook = gtk_notebook_new();
gtk_notebook_set_show_tabs(GTK_NOTEBOOK(priv->notebook), FALSE);
gtk_grid_attach(GTK_GRID(priv->grid), priv->notebook, 0, 1, 1, 1); gtk_grid_attach(GTK_GRID(priv->grid), priv->notebook, 0, 1, 1, 1);
tab = notebook_edit(window);
priv->tab_edit = gtk_notebook_append_page(GTK_NOTEBOOK(priv->notebook), tab, NULL);
placeholder = gtk_label_new("PLACEHOLDER FOR THE CHART WEBKIT"); placeholder = gtk_label_new("PLACEHOLDER FOR THE CHART WEBKIT");
priv->tab_chart = gtk_notebook_append_page(GTK_NOTEBOOK(priv->notebook), placeholder, NULL); priv->tab_chart = gtk_notebook_append_page(GTK_NOTEBOOK(priv->notebook), placeholder, NULL);
@ -142,7 +259,8 @@ window_populate(AgWindow *window)
placeholder = gtk_label_new("PLACEHOLDER FOR THE POINTS TABLES"); placeholder = gtk_label_new("PLACEHOLDER FOR THE POINTS TABLES");
priv->tab_points = gtk_notebook_append_page(GTK_NOTEBOOK(priv->notebook), placeholder, NULL); priv->tab_points = gtk_notebook_append_page(GTK_NOTEBOOK(priv->notebook), placeholder, NULL);
gtk_notebook_set_show_tabs(GTK_NOTEBOOK(priv->notebook), FALSE); /* TODO: change to the Chart tab if we are opening an existing chart! */
gtk_notebook_set_current_page(GTK_NOTEBOOK(priv->notebook), priv->tab_edit);
gtk_widget_show_all(priv->grid); gtk_widget_show_all(priv->grid);
} }

View File

@ -48,6 +48,12 @@
<attribute name="target">points</attribute> <attribute name="target">points</attribute>
<attribute name="accel">F8</attribute> <attribute name="accel">F8</attribute>
</item> </item>
<item>
<attribute name="label" translatable="yes">Edit chart</attribute>
<attribute name="action">win.tab-change</attribute>
<attribute name="target">edit</attribute>
<attribute name="accel">&lt;Shift&gt;F3</attribute>
</item>
</section> </section>
</menu> </menu>
</interface> </interface>