4 * Copyright (C) 2008 - 2009 The Geeqie Team
6 * Author: Vladimir Nadvornik
8 * This software is released under the GNU General Public License (GNU GPL).
9 * Please read the included file COPYING for more information.
10 * This software comes with no warranty of any kind, use at your own risk!
18 #include "history_list.h"
21 #include "ui_fileops.h"
23 #include "ui_utildlg.h"
26 #include "bar_comment.h"
27 #include "bar_keywords.h"
29 #include "bar_histogram.h"
30 #include "histogram.h"
33 typedef struct _KnownPanes KnownPanes;
41 static const KnownPanes known_panes[] = {
43 {PANE_HISTOGRAM, "histogram", N_("Histogram")},
44 {PANE_COMMENT, "title", N_("Title")},
45 {PANE_KEYWORDS, "keywords", N_("Keywords")},
46 {PANE_COMMENT, "comment", N_("Comment")},
47 {PANE_EXIF, "exif", N_("Exif")},
49 {PANE_UNDEF, NULL, NULL}
52 typedef struct _BarData BarData;
58 GtkWidget *label_file_name;
64 static void bar_expander_move(GtkWidget *widget, gpointer data, gboolean up)
66 GtkWidget *expander = data;
70 if (!expander) return;
71 box = gtk_widget_get_ancestor(expander, GTK_TYPE_BOX);
74 gtk_container_child_get(GTK_CONTAINER(box), expander, "position", &pos, NULL);
76 pos = up ? (pos - 1) : (pos + 1);
79 gtk_box_reorder_child(GTK_BOX(box), expander, pos);
83 static void bar_expander_move_up_cb(GtkWidget *widget, gpointer data)
85 bar_expander_move(widget, data, TRUE);
88 static void bar_expander_move_down_cb(GtkWidget *widget, gpointer data)
90 bar_expander_move(widget, data, FALSE);
94 static void bar_expander_menu_popup(GtkWidget *data)
98 menu = popup_menu_short_lived();
100 menu_item_add_stock(menu, _("Move _up"), GTK_STOCK_GO_UP, G_CALLBACK(bar_expander_move_up_cb), data);
101 menu_item_add_stock(menu, _("Move _down"), GTK_STOCK_GO_DOWN, G_CALLBACK(bar_expander_move_down_cb), data);
102 gtk_menu_popup(GTK_MENU(menu), NULL, NULL, NULL, data, 0, GDK_CURRENT_TIME);
106 static gboolean bar_expander_menu_cb(GtkWidget *widget, GdkEventButton *bevent, gpointer data)
108 if (bevent->button == MOUSE_BUTTON_RIGHT)
110 bar_expander_menu_popup(widget);
117 void bar_pane_set_fd_cb(GtkWidget *expander, gpointer data)
119 GtkWidget *widget = gtk_bin_get_child(GTK_BIN(expander));
120 PaneData *pd = g_object_get_data(G_OBJECT(widget), "pane_data");
122 if (pd->pane_set_fd) pd->pane_set_fd(widget, data);
125 void bar_set_fd(GtkWidget *bar, FileData *fd)
128 bd = g_object_get_data(G_OBJECT(bar), "bar_data");
131 file_data_unref(bd->fd);
132 bd->fd = file_data_ref(fd);
134 gtk_container_foreach(GTK_CONTAINER(bd->vbox), bar_pane_set_fd_cb, fd);
136 gtk_label_set_text(GTK_LABEL(bd->label_file_name), (bd->fd) ? bd->fd->name : "");
140 gboolean bar_event(GtkWidget *bar, GdkEvent *event)
144 gboolean ret = FALSE;
146 bd = g_object_get_data(G_OBJECT(bar), "bar_data");
147 if (!bd) return FALSE;
149 list = gtk_container_get_children(GTK_CONTAINER(bd->vbox));
154 GtkWidget *widget = gtk_bin_get_child(GTK_BIN(work->data));
155 PaneData *pd = g_object_get_data(G_OBJECT(widget), "pane_data");
158 if (pd->pane_event && pd->pane_event(widget, event))
169 GtkWidget *bar_find_pane_by_id(GtkWidget *bar, PaneType type, const gchar *id)
173 GtkWidget *ret = NULL;
175 if (!id || !id[0]) return NULL;
177 bd = g_object_get_data(G_OBJECT(bar), "bar_data");
178 if (!bd) return NULL;
180 list = gtk_container_get_children(GTK_CONTAINER(bd->vbox));
185 GtkWidget *widget = gtk_bin_get_child(GTK_BIN(work->data));
186 PaneData *pd = g_object_get_data(G_OBJECT(widget), "pane_data");
189 if (type == pd->type && strcmp(id, pd->id) == 0)
200 void bar_clear(GtkWidget *bar)
205 bd = g_object_get_data(G_OBJECT(bar), "bar_data");
208 list = gtk_container_get_children(GTK_CONTAINER(bd->vbox));
213 GtkWidget *widget = work->data;
214 gtk_widget_destroy(widget);
220 void bar_write_config(GtkWidget *bar, GString *outstr, gint indent)
227 bd = g_object_get_data(G_OBJECT(bar), "bar_data");
230 WRITE_NL(); WRITE_STRING("<bar ");
231 write_bool_option(outstr, indent, "enabled", GTK_WIDGET_VISIBLE(bar));
232 write_uint_option(outstr, indent, "width", bd->width);
236 WRITE_NL(); WRITE_STRING("<clear/>");
238 list = gtk_container_get_children(GTK_CONTAINER(bd->vbox));
242 GtkWidget *expander = work->data;
243 GtkWidget *widget = gtk_bin_get_child(GTK_BIN(expander));
244 PaneData *pd = g_object_get_data(G_OBJECT(widget), "pane_data");
247 pd->expanded = gtk_expander_get_expanded(GTK_EXPANDER(expander));
249 if (pd->pane_write_config)
250 pd->pane_write_config(widget, outstr, indent);
256 WRITE_NL(); WRITE_STRING("</bar>");
259 void bar_update_expander(GtkWidget *pane)
261 PaneData *pd = g_object_get_data(G_OBJECT(pane), "pane_data");
266 expander = pane->parent;
268 gtk_expander_set_expanded(GTK_EXPANDER(expander), pd->expanded);
271 void bar_add(GtkWidget *bar, GtkWidget *pane)
274 BarData *bd = g_object_get_data(G_OBJECT(bar), "bar_data");
275 PaneData *pd = g_object_get_data(G_OBJECT(pane), "pane_data");
282 expander = gtk_expander_new(NULL);
285 gtk_expander_set_label_widget(GTK_EXPANDER(expander), pd->title);
286 gtk_widget_show(pd->title);
289 gtk_box_pack_start(GTK_BOX(bd->vbox), expander, FALSE, TRUE, 0);
291 g_signal_connect(expander, "button_press_event", G_CALLBACK(bar_expander_menu_cb), bd);
293 gtk_container_add(GTK_CONTAINER(expander), pane);
295 gtk_expander_set_expanded(GTK_EXPANDER(expander), pd->expanded);
297 gtk_widget_show(expander);
299 if (bd->fd && pd && pd->pane_set_fd) pd->pane_set_fd(pane, bd->fd);
303 static void bar_populate_default(GtkWidget *bar)
307 widget = bar_pane_histogram_new("histogram", _("Histogram"), 80, TRUE, HCHAN_RGB, 0);
308 bar_add(bar, widget);
310 widget = bar_pane_comment_new("title", _("Title"), "Xmp.dc.title", TRUE, 40);
311 bar_add(bar, widget);
313 widget = bar_pane_keywords_new("keywords", _("Keywords"), KEYWORD_KEY, TRUE);
314 bar_add(bar, widget);
316 widget = bar_pane_comment_new("comment", _("Comment"), "Xmp.dc.description", TRUE, 150);
317 bar_add(bar, widget);
319 widget = bar_pane_exif_new("exif", _("Exif"), TRUE, TRUE);
320 bar_add(bar, widget);
323 static void bar_size_allocate(GtkWidget *widget, GtkAllocation *allocation, gpointer data)
327 bd->width = allocation->width;
330 gint bar_get_width(GtkWidget *bar)
334 bd = g_object_get_data(G_OBJECT(bar), "bar_data");
340 void bar_close(GtkWidget *bar)
344 bd = g_object_get_data(G_OBJECT(bar), "bar_data");
347 gtk_widget_destroy(bd->widget);
350 static void bar_destroy(GtkWidget *widget, gpointer data)
354 file_data_unref(bd->fd);
358 GtkWidget *bar_new(LayoutWindow *lw)
364 bd = g_new0(BarData, 1);
368 bd->widget = gtk_vbox_new(FALSE, PREF_PAD_GAP);
369 g_object_set_data(G_OBJECT(bd->widget), "bar_data", bd);
370 g_signal_connect(G_OBJECT(bd->widget), "destroy",
371 G_CALLBACK(bar_destroy), bd);
373 g_signal_connect(G_OBJECT(bd->widget), "size-allocate",
374 G_CALLBACK(bar_size_allocate), bd);
376 bd->width = SIDEBAR_DEFAULT_WIDTH;
377 gtk_widget_set_size_request(bd->widget, bd->width, -1);
379 box = gtk_hbox_new(FALSE, 0);
381 bd->label_file_name = gtk_label_new("");
382 gtk_label_set_ellipsize(GTK_LABEL(bd->label_file_name), PANGO_ELLIPSIZE_END);
383 gtk_label_set_selectable(GTK_LABEL(bd->label_file_name), TRUE);
384 gtk_misc_set_alignment(GTK_MISC(bd->label_file_name), 0.5, 0.5);
385 gtk_box_pack_start(GTK_BOX(box), bd->label_file_name, TRUE, TRUE, 0);
386 gtk_widget_show(bd->label_file_name);
388 gtk_box_pack_start(GTK_BOX(bd->widget), box, FALSE, FALSE, 0);
389 gtk_widget_show(box);
391 scrolled = gtk_scrolled_window_new(NULL, NULL);
392 gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled),
393 GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC);
394 gtk_box_pack_start(GTK_BOX(bd->widget), scrolled, TRUE, TRUE, 0);
395 gtk_widget_show(scrolled);
398 bd->vbox = gtk_vbox_new(FALSE, 0);
399 gtk_scrolled_window_add_with_viewport(GTK_SCROLLED_WINDOW(scrolled), bd->vbox);
400 gtk_viewport_set_shadow_type(GTK_VIEWPORT(gtk_bin_get_child(GTK_BIN(scrolled))), GTK_SHADOW_NONE);
402 gtk_scrolled_window_set_shadow_type(GTK_SCROLLED_WINDOW(scrolled), GTK_SHADOW_NONE);
403 gtk_widget_show(bd->vbox);
407 GtkWidget *bar_new_default(LayoutWindow *lw)
409 GtkWidget *bar = bar_new(lw);
411 bar_populate_default(bar);
413 gtk_widget_show(bar);
418 GtkWidget *bar_update_from_config(GtkWidget *bar, const gchar **attribute_names, const gchar **attribute_values)
420 gboolean enabled = TRUE;
421 gint width = SIDEBAR_DEFAULT_WIDTH;
423 while (*attribute_names)
425 const gchar *option = *attribute_names++;
426 const gchar *value = *attribute_values++;
428 if (READ_BOOL_FULL("enabled", enabled)) continue;
429 if (READ_INT_FULL("width", width)) continue;
432 log_printf("unknown attribute %s = %s\n", option, value);
435 gtk_widget_set_size_request(bar, width, -1);
438 gtk_widget_show(bar);
442 gtk_widget_hide(bar);
447 GtkWidget *bar_new_from_config(LayoutWindow *lw, const gchar **attribute_names, const gchar **attribute_values)
449 GtkWidget *bar = bar_new(lw);
450 return bar_update_from_config(bar, attribute_names, attribute_values);
453 GtkWidget *bar_pane_expander_title(const gchar *title)
455 GtkWidget *widget = gtk_label_new(title);
457 pref_label_bold(widget, TRUE, FALSE);
458 //gtk_label_set_ellipsize(GTK_LABEL(widget), PANGO_ELLIPSIZE_END); //FIXME: do not work
463 gboolean bar_pane_translate_title(PaneType type, const gchar *id, gchar **title)
465 const KnownPanes *pane = known_panes;
467 if (!title) return FALSE;
470 if (pane->type == type && strcmp(pane->id, id) == 0) break;
473 if (!pane->id) return FALSE;
475 if (*title && **title && strcmp(pane->title, *title) != 0) return FALSE;
478 *title = g_strdup(_(pane->title));
482 /* vim: set shiftwidth=8 softtabstop=0 cindent cinoptions={1s: */