mirror of
https://github.com/subsurface/subsurface.git
synced 2025-02-19 22:16:15 +00:00
Add some extended dive info fields
.. and tweak the basic info layout a bit. Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
23c6a42b08
commit
feec555040
2 changed files with 53 additions and 22 deletions
72
info.c
72
info.c
|
@ -5,7 +5,16 @@
|
||||||
#include "dive.h"
|
#include "dive.h"
|
||||||
#include "display.h"
|
#include "display.h"
|
||||||
|
|
||||||
static GtkWidget *datetime, *depth, *duration;
|
static GtkWidget *divedate, *divetime, *depth, *duration;
|
||||||
|
static GtkWidget *location, *notes;
|
||||||
|
|
||||||
|
static const char *weekday(int wday)
|
||||||
|
{
|
||||||
|
static const char wday_array[7][4] = {
|
||||||
|
"Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"
|
||||||
|
};
|
||||||
|
return wday_array[wday];
|
||||||
|
}
|
||||||
|
|
||||||
void update_dive_info(struct dive *dive)
|
void update_dive_info(struct dive *dive)
|
||||||
{
|
{
|
||||||
|
@ -13,29 +22,42 @@ void update_dive_info(struct dive *dive)
|
||||||
char buffer[80];
|
char buffer[80];
|
||||||
|
|
||||||
if (!dive) {
|
if (!dive) {
|
||||||
gtk_entry_set_text(GTK_ENTRY(datetime), "no dive");
|
gtk_label_set_text(GTK_LABEL(divedate), "no dive");
|
||||||
gtk_entry_set_text(GTK_ENTRY(depth), "");
|
gtk_label_set_text(GTK_LABEL(divetime), "");
|
||||||
gtk_entry_set_text(GTK_ENTRY(duration), "");
|
gtk_label_set_text(GTK_LABEL(depth), "");
|
||||||
|
gtk_label_set_text(GTK_LABEL(duration), "");
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
tm = gmtime(&dive->when);
|
tm = gmtime(&dive->when);
|
||||||
snprintf(buffer, sizeof(buffer),
|
snprintf(buffer, sizeof(buffer),
|
||||||
"%04d-%02d-%02d "
|
"%s %02d/%02d/%04d",
|
||||||
|
weekday(tm->tm_wday),
|
||||||
|
tm->tm_mon+1, tm->tm_mday, tm->tm_year+1900);
|
||||||
|
gtk_label_set_text(GTK_LABEL(divedate), buffer);
|
||||||
|
|
||||||
|
snprintf(buffer, sizeof(buffer),
|
||||||
"%02d:%02d:%02d",
|
"%02d:%02d:%02d",
|
||||||
tm->tm_year+1900, tm->tm_mon+1, tm->tm_mday,
|
|
||||||
tm->tm_hour, tm->tm_min, tm->tm_sec);
|
tm->tm_hour, tm->tm_min, tm->tm_sec);
|
||||||
gtk_entry_set_text(GTK_ENTRY(datetime), buffer);
|
gtk_label_set_text(GTK_LABEL(divetime), buffer);
|
||||||
|
|
||||||
snprintf(buffer, sizeof(buffer),
|
snprintf(buffer, sizeof(buffer),
|
||||||
"%d ft",
|
"%d ft",
|
||||||
to_feet(dive->maxdepth));
|
to_feet(dive->maxdepth));
|
||||||
gtk_entry_set_text(GTK_ENTRY(depth), buffer);
|
gtk_label_set_text(GTK_LABEL(depth), buffer);
|
||||||
|
|
||||||
snprintf(buffer, sizeof(buffer),
|
snprintf(buffer, sizeof(buffer),
|
||||||
"%d min",
|
"%d min",
|
||||||
dive->duration.seconds / 60);
|
dive->duration.seconds / 60);
|
||||||
gtk_entry_set_text(GTK_ENTRY(duration), buffer);
|
gtk_label_set_text(GTK_LABEL(duration), buffer);
|
||||||
|
}
|
||||||
|
|
||||||
|
static GtkWidget *info_label(GtkWidget *box, const char *str)
|
||||||
|
{
|
||||||
|
GtkWidget *label = gtk_label_new(str);
|
||||||
|
gtk_label_set_justify(GTK_LABEL(label), GTK_JUSTIFY_RIGHT);
|
||||||
|
gtk_box_pack_start(GTK_BOX(box), label, TRUE, TRUE, 0);
|
||||||
|
return label;
|
||||||
}
|
}
|
||||||
|
|
||||||
GtkWidget *dive_info_frame(void)
|
GtkWidget *dive_info_frame(void)
|
||||||
|
@ -46,24 +68,28 @@ GtkWidget *dive_info_frame(void)
|
||||||
frame = gtk_frame_new("Dive info");
|
frame = gtk_frame_new("Dive info");
|
||||||
gtk_widget_show(frame);
|
gtk_widget_show(frame);
|
||||||
|
|
||||||
hbox = gtk_hbox_new(FALSE, 5);
|
hbox = gtk_hbox_new(TRUE, 5);
|
||||||
|
gtk_container_set_border_width(GTK_CONTAINER(hbox), 3);
|
||||||
gtk_container_add(GTK_CONTAINER(frame), hbox);
|
gtk_container_add(GTK_CONTAINER(frame), hbox);
|
||||||
|
|
||||||
datetime = gtk_entry_new();
|
divedate = info_label(hbox, "date");
|
||||||
gtk_editable_set_editable(GTK_EDITABLE(datetime), FALSE);
|
divetime = info_label(hbox, "time");
|
||||||
gtk_box_pack_start(GTK_BOX(hbox), datetime, FALSE, FALSE, 0);
|
depth = info_label(hbox, "depth");
|
||||||
|
duration = info_label(hbox, "duration");
|
||||||
depth = gtk_entry_new();
|
|
||||||
gtk_editable_set_editable(GTK_EDITABLE(depth), FALSE);
|
|
||||||
gtk_box_pack_start(GTK_BOX(hbox), depth, FALSE, FALSE, 0);
|
|
||||||
|
|
||||||
duration = gtk_entry_new();
|
|
||||||
gtk_editable_set_editable(GTK_EDITABLE(duration), FALSE);
|
|
||||||
gtk_box_pack_start(GTK_BOX(hbox), duration, FALSE, FALSE, 0);
|
|
||||||
|
|
||||||
return frame;
|
return frame;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static GtkWidget *text_entry(GtkWidget *box, const char *label)
|
||||||
|
{
|
||||||
|
GtkWidget *entry;
|
||||||
|
GtkWidget *frame = gtk_frame_new(label);
|
||||||
|
gtk_box_pack_start(GTK_BOX(box), frame, FALSE, FALSE, 0);
|
||||||
|
entry = gtk_entry_new();
|
||||||
|
gtk_container_add(GTK_CONTAINER(frame), entry);
|
||||||
|
return entry;
|
||||||
|
}
|
||||||
|
|
||||||
GtkWidget *extended_dive_info_frame(void)
|
GtkWidget *extended_dive_info_frame(void)
|
||||||
{
|
{
|
||||||
GtkWidget *frame;
|
GtkWidget *frame;
|
||||||
|
@ -75,6 +101,10 @@ GtkWidget *extended_dive_info_frame(void)
|
||||||
vbox = gtk_vbox_new(FALSE, 5);
|
vbox = gtk_vbox_new(FALSE, 5);
|
||||||
gtk_container_add(GTK_CONTAINER(frame), vbox);
|
gtk_container_add(GTK_CONTAINER(frame), vbox);
|
||||||
|
|
||||||
|
location = text_entry(vbox, "Location");
|
||||||
|
notes = text_entry(vbox, "Notes");
|
||||||
|
location = gtk_entry_new();
|
||||||
|
|
||||||
/* Add extended info here: name, description, yadda yadda */
|
/* Add extended info here: name, description, yadda yadda */
|
||||||
update_dive_info(current_dive);
|
update_dive_info(current_dive);
|
||||||
return frame;
|
return frame;
|
||||||
|
|
3
main.c
3
main.c
|
@ -173,7 +173,8 @@ int main(int argc, char **argv)
|
||||||
|
|
||||||
/* Frame for minimal dive info */
|
/* Frame for minimal dive info */
|
||||||
frame = dive_info_frame();
|
frame = dive_info_frame();
|
||||||
gtk_table_attach(GTK_TABLE(table), frame, 1, 2, 0, 1, 0, 0, 0, 0);
|
gtk_table_attach(GTK_TABLE(table), frame, 1, 2, 0, 1,
|
||||||
|
GTK_FILL | GTK_SHRINK | GTK_EXPAND, 0, 0, 0);
|
||||||
|
|
||||||
/* Notebook for dive info vs profile vs .. */
|
/* Notebook for dive info vs profile vs .. */
|
||||||
notebook = gtk_notebook_new();
|
notebook = gtk_notebook_new();
|
||||||
|
|
Loading…
Add table
Reference in a new issue