okra pushed a commit to branch master.

http://git.enlightenment.org/apps/ephoto.git/commit/?id=2e6998b0c089b97e61b9281911073707e50332ea

commit 2e6998b0c089b97e61b9281911073707e50332ea
Author: Stephen Houston <smhousto...@gmail.com>
Date:   Tue Dec 1 23:03:50 2015 -0600

    Ephoto: Allow delete from the single view, Add a right click edit menu to 
the single view, Expand fsel on double click
---
 src/bin/ephoto_config.c         |  91 ++++++++++--
 src/bin/ephoto_single_browser.c | 306 ++++++++++++++++++++++++++++++++++++++--
 src/bin/ephoto_thumb_browser.c  |  82 ++++++++---
 3 files changed, 437 insertions(+), 42 deletions(-)

diff --git a/src/bin/ephoto_config.c b/src/bin/ephoto_config.c
index 04906d7..47121a0 100644
--- a/src/bin/ephoto_config.c
+++ b/src/bin/ephoto_config.c
@@ -365,10 +365,61 @@ ephoto_config_slideshow(Ephoto *ephoto)
    evas_object_show(popup);
 }
 
+static void
+_link_anchor_bt(void *data, Evas_Object *obj,
+    void *event_info EINA_UNUSED)
+{
+   char buf[PATH_MAX];
+   Evas_Object *av = data;
+   const char *link = evas_object_data_get(obj, "link");
+
+   elm_entry_anchor_hover_end(av);
+   snprintf(buf, PATH_MAX, "xdg-open %s", link);
+   ecore_exe_run(buf, NULL);
+}
+
+static void
+_copy_anchor_bt(void *data, Evas_Object *obj,
+    void *event_info EINA_UNUSED)
+{
+   char buf[PATH_MAX];
+   Evas_Object *av = data;
+   const char *link = evas_object_data_get(obj, "link");
+
+   elm_entry_anchor_hover_end(av);
+   snprintf(buf, PATH_MAX, "%s", link);
+   elm_cnp_selection_set(av, ELM_SEL_TYPE_CLIPBOARD, ELM_SEL_FORMAT_MARKUP,
+       buf, strlen(buf));
+}
+
+static void
+_link_anchor(void *data, Evas_Object *obj, void *event_info)
+{
+   Evas_Object *av = data;
+   Evas_Object *button;
+   Elm_Entry_Anchor_Hover_Info *ei = event_info;
+
+   button = elm_button_add(obj);
+   elm_object_text_set(button, _("Open Link In Browser"));
+   elm_object_part_content_set(ei->hover, "middle", button);
+   evas_object_smart_callback_add(button, "clicked", _link_anchor_bt,
+       av);
+   evas_object_data_set(button, "link", strdup(ei->anchor_info->name));
+   evas_object_show(button);
+
+   button = elm_button_add(obj);
+   elm_object_text_set(button, _("Copy Link"));
+   elm_object_part_content_set(ei->hover, "bottom", button);
+   evas_object_smart_callback_add(button, "clicked", _copy_anchor_bt,
+       av);
+   evas_object_data_set(button, "link", strdup(ei->anchor_info->name));
+   evas_object_show(button);
+}
+
 void
 ephoto_config_about(Ephoto *ephoto)
 {
-   Evas_Object *popup, *box, *ic, *button, *label;
+   Evas_Object *popup, *box, *bb, *entry, *ic, *button;
    Eina_Strbuf *sbuf = eina_strbuf_new();
    FILE *f;
 
@@ -383,15 +434,29 @@ ephoto_config_about(Ephoto *ephoto)
    evas_object_size_hint_align_set(box, EVAS_HINT_FILL, EVAS_HINT_FILL);
    evas_object_show(box);
 
-   label = elm_label_add(box);
-   evas_object_size_hint_weight_set(label, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
-   evas_object_size_hint_align_set(label, EVAS_HINT_FILL, EVAS_HINT_FILL);
+   bb = elm_bubble_add(box);
+   evas_object_size_hint_weight_set(bb, 0.0, 0.0);
+   evas_object_size_hint_align_set(bb, EVAS_HINT_FILL, EVAS_HINT_FILL);
+   elm_box_pack_end(box, bb);
+   evas_object_show(bb);
+
+   entry = elm_entry_add(bb);
+   elm_entry_anchor_hover_style_set(entry, "popout");
+   elm_entry_anchor_hover_parent_set(entry, popup);
+   elm_entry_editable_set(entry, EINA_FALSE);
+   elm_entry_context_menu_disabled_set(entry, EINA_TRUE);
+   elm_entry_line_wrap_set(entry, ELM_WRAP_NONE);
+   evas_object_size_hint_weight_set(entry, 0.0, 0.0);
+   evas_object_size_hint_align_set(entry, EVAS_HINT_FILL, EVAS_HINT_FILL);
    eina_strbuf_append_printf(sbuf,
        _("Ephoto is a comprehensive image viewer based on the EFL.<br/>"
-          "For more information, please visit the Ephoto project page on the 
Enlightenment wiki:<br/>"
-          "https://phab.enlightenment.org/w/projects/ephoto<br/>"
+          "For more information, please visit the Ephoto project page on<br/>"
+           "the Enlightenment wiki:<br/>"
+          "<a href=https://phab.enlightenment.org/w/projects/ephoto>"
+           "https://phab.enlightenment.org/w/projects/ephoto</a><br/><br/>"
           "Ephoto's source can be found through Enlightenment's git:<br/>"
-          "http://git.enlightenment.org/apps/ephoto.git<br/>" "<br/>"
+          "<a href=http://git.enlightenment.org/apps/ephoto.git>"
+           "http://git.enlightenment.org/apps/ephoto.git</a><br/><br/>"
           "<b>Authors:</b><br/>"));
    f = fopen(PACKAGE_DATA_DIR "/AUTHORS", "r");
    if (f)
@@ -428,17 +493,19 @@ ephoto_config_about(Ephoto *ephoto)
                               *p = 0;
                         }
                       while (p);
-                      eina_strbuf_append_printf(sbuf, "%s<br>", buf);
+                      eina_strbuf_append_printf(sbuf, "%s<br/>", buf);
                    }
                  if (len == 0)
-                    eina_strbuf_append_printf(sbuf, "<br>");
+                    eina_strbuf_append_printf(sbuf, "<br/>");
               }
          }
        fclose(f);
      }
-   elm_object_text_set(label, eina_strbuf_string_get(sbuf));
-   elm_box_pack_end(box, label);
-   evas_object_show(label);
+   elm_object_text_set(entry, eina_strbuf_string_get(sbuf));
+   evas_object_smart_callback_add(entry, "anchor,hover,opened",
+       _link_anchor, entry);
+   elm_object_content_set(bb, entry);
+   evas_object_show(entry);
 
    ic = elm_icon_add(box);
    elm_icon_order_lookup_set(ic, ELM_ICON_LOOKUP_FDO_THEME);
diff --git a/src/bin/ephoto_single_browser.c b/src/bin/ephoto_single_browser.c
index 876d5d1..b95ec34 100644
--- a/src/bin/ephoto_single_browser.c
+++ b/src/bin/ephoto_single_browser.c
@@ -50,6 +50,7 @@ static void _zoom_in(Ephoto_Single_Browser *sb);
 static void _zoom_out(Ephoto_Single_Browser *sb);
 static void _key_down(void *data, Evas *e EINA_UNUSED,
     Evas_Object *obj EINA_UNUSED, void *event_info);
+static void _edit_menu(Ephoto_Single_Browser *sb);
 
 static void
 _viewer_del(void *data, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED,
@@ -91,7 +92,6 @@ _1s_hold_time(void *data)
 {
    const char *f;
    char dd[PATH_MAX];
-
    Evas_Object *io = data;
 
    elm_image_file_get(io, &f, NULL);
@@ -105,23 +105,45 @@ _1s_hold_time(void *data)
 }
 
 static void
-_image_mouse_down_cb(void *data, Evas *e EINA_UNUSED,
-    Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
+_image_mouse_down_cb(void *data EINA_UNUSED, Evas *e EINA_UNUSED,
+    Evas_Object *obj, void *event_info)
 {
-   Evas_Object *io = data;
+   Evas_Object *io = obj;
+   Evas_Event_Mouse_Down *ev = event_info;
 
-   _1s_hold = ecore_timer_add(0.5, _1s_hold_time, io);
+   if (ev->flags != EVAS_BUTTON_NONE)
+     {
+        ecore_timer_del(_1s_hold);
+        _1s_hold = NULL;
+     }
+   else if (ev->button == 1)
+     {
+        _1s_hold = ecore_timer_add(0.5, _1s_hold_time, io);
+     }
 }
 
 static void
-_image_mouse_up_cb(void *data EINA_UNUSED, Evas *e EINA_UNUSED,
-    Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
+_image_mouse_up_cb(void *data, Evas *e EINA_UNUSED,
+    Evas_Object *obj EINA_UNUSED, void *event_info)
 {
-   ecore_timer_del(_1s_hold);
+   Ephoto_Single_Browser *sb = data;
+   Evas_Event_Mouse_Up *ev = event_info;
+
+   if ((ev->button == 1) && (ev->flags == EVAS_BUTTON_DOUBLE_CLICK))
+     {
+         ecore_timer_del(_1s_hold);
+         _1s_hold = NULL;
+         elm_win_fullscreen_set(sb->ephoto->win,
+            !elm_win_fullscreen_get(sb->ephoto->win));
+     }
+   else if (ev->button == 3)
+     {
+        _edit_menu(sb);
+     }
 }
 
 static Evas_Object *
-_viewer_add(Evas_Object *parent, const char *path)
+_viewer_add(Evas_Object *parent, const char *path, Ephoto_Single_Browser *sb)
 {
    Ephoto_Viewer *v = calloc(1, sizeof(Ephoto_Viewer));
    int err;
@@ -176,9 +198,9 @@ _viewer_add(Evas_Object *parent, const char *path)
    evas_object_size_hint_min_set(v->image, w, h);
    evas_object_size_hint_max_set(v->image, w, h);
    evas_object_event_callback_add(v->image, EVAS_CALLBACK_MOUSE_DOWN,
-       _image_mouse_down_cb, v->image);
+       _image_mouse_down_cb, sb);
    evas_object_event_callback_add(v->image, EVAS_CALLBACK_MOUSE_UP,
-       _image_mouse_up_cb, v->image);
+       _image_mouse_up_cb, sb);
    elm_table_pack(v->table, v->image, 0, 0, 1, 1);
    evas_object_show(v->image);
 
@@ -651,7 +673,7 @@ _ephoto_single_browser_recalc(Ephoto_Single_Browser *sb)
 
        elm_table_clear(sb->table, EINA_FALSE);
 
-       sb->viewer = _viewer_add(sb->main, sb->entry->path);
+       sb->viewer = _viewer_add(sb->main, sb->entry->path, sb);
        if (sb->viewer)
          {
             char image_info[PATH_MAX], *tmp;
@@ -815,7 +837,8 @@ _prev_entry(Ephoto_Single_Browser *sb)
 {
    Eina_List *node;
    Ephoto_Entry *entry = NULL;
-
+   printf("Hi\n");
+   printf("%s\n", sb->entry->path);
    node = eina_list_data_find_list(sb->ephoto->entries, sb->entry);
    if (!node)
       return;
@@ -1676,6 +1699,188 @@ _upload_image(void *data, Evas_Object *obj EINA_UNUSED,
 }
 
 static void
+_error_ok(void *data, Evas_Object *obj EINA_UNUSED,
+    void *event_info EINA_UNUSED)
+{
+   Evas_Object *popup = data;
+   Ephoto_Single_Browser *sb = evas_object_data_get(popup, "single_browser");
+
+   evas_object_del(popup);
+   if (sb->event)
+     {
+        evas_object_freeze_events_set(sb->event, EINA_FALSE);
+        elm_object_focus_set(sb->event, EINA_TRUE);
+     }
+}
+
+static void
+_delete_apply(void *data, Evas_Object *obj EINA_UNUSED,
+    void *event_info EINA_UNUSED)
+{
+   Evas_Object *popup = data;
+   Ephoto_Single_Browser *sb = evas_object_data_get(popup, "single_browser");
+   char destination[PATH_MAX];
+   int ret;
+
+   snprintf(destination, PATH_MAX, "%s/.config/ephoto/trash", getenv("HOME"));
+
+   if (!ecore_file_exists(destination))
+      ecore_file_mkpath(destination);
+
+   if (ecore_file_exists(sb->entry->path) && ecore_file_is_dir(destination))
+     {
+        char dest[PATH_MAX], fp[PATH_MAX], extra[PATH_MAX];
+        
+        snprintf(fp, PATH_MAX, "%s", sb->entry->path);
+        snprintf(dest, PATH_MAX, "%s/%s", destination, basename(fp));
+        if (ecore_file_exists(dest))
+          {
+             snprintf(extra, PATH_MAX, "%s/CopyOf%s", destination,
+                 basename(fp));
+             if (ecore_file_exists(extra))
+               {
+                  int count;
+
+                  for (count = 2; ecore_file_exists(extra); count++)
+                    {
+                       memset(extra, 0, sizeof(extra));
+                       snprintf(extra, PATH_MAX, "%s/Copy%dOf%s",
+                           destination, count, basename(fp));
+                    }
+               }
+             ret = ecore_file_mv(sb->entry->path, extra);
+          }
+        else
+          ret = ecore_file_mv(sb->entry->path, dest);
+        if (!ret)
+          {
+             Evas_Object *ppopup, *box, *label, *ic, *button;
+
+             if (sb->event)
+               evas_object_freeze_events_set(sb->event, EINA_TRUE);
+
+             ppopup = elm_popup_add(sb->ephoto->win);
+             elm_object_part_text_set(ppopup, "title,text", _("Error"));
+             elm_popup_orient_set(ppopup, ELM_POPUP_ORIENT_CENTER);
+
+             box = elm_box_add(ppopup);
+             elm_box_horizontal_set(box, EINA_FALSE);
+             evas_object_size_hint_weight_set(box, EVAS_HINT_FILL, 
EVAS_HINT_FILL);
+             evas_object_size_hint_align_set(box, EVAS_HINT_FILL, 
EVAS_HINT_FILL);
+             evas_object_show(box);
+
+             label = elm_label_add(box);
+             elm_object_text_set(label, _("There was an error deleting this 
file"));
+             evas_object_size_hint_weight_set(label, EVAS_HINT_EXPAND, 
EVAS_HINT_EXPAND);
+             evas_object_size_hint_align_set(label, EVAS_HINT_FILL, 
EVAS_HINT_FILL);
+             elm_box_pack_end(box, label);
+             evas_object_show(label);
+
+             ic = elm_icon_add(ppopup);
+             elm_icon_order_lookup_set(ic, ELM_ICON_LOOKUP_FDO_THEME);
+             evas_object_size_hint_aspect_set(ic, 
EVAS_ASPECT_CONTROL_VERTICAL, 1, 1);
+             elm_icon_standard_set(ic, "window-close");
+
+             button = elm_button_add(ppopup);
+             elm_object_text_set(button, _("Ok"));
+             elm_object_part_content_set(button, "icon", ic);
+             evas_object_smart_callback_add(button, "clicked", _error_ok, 
popup);
+             elm_object_part_content_set(popup, "button1", button);
+             evas_object_show(button);
+
+             evas_object_data_set(ppopup, "single_browser", sb);
+             elm_object_part_content_set(ppopup, "default", box);
+             evas_object_show(ppopup);
+          }
+     }
+   evas_object_del(popup);
+   if (sb->event)
+     {
+        elm_object_focus_set(sb->event, EINA_TRUE);
+        evas_object_freeze_events_set(sb->event, EINA_FALSE);
+     }
+   ephoto_directory_set(sb->ephoto, sb->ephoto->config->directory,
+       NULL, EINA_FALSE, EINA_TRUE);
+   ephoto_title_set(sb->ephoto, sb->ephoto->config->directory);
+   evas_object_smart_callback_call(sb->main, "back", NULL);
+}
+
+static void
+_delete_cancel(void *data, Evas_Object *obj EINA_UNUSED,
+    void *event_info EINA_UNUSED)
+{
+   Evas_Object *popup = data;
+   Ephoto_Single_Browser *sb = evas_object_data_get(popup, "single_browser");
+
+   evas_object_del(popup);
+   if (sb->event)
+     {
+        elm_object_focus_set(sb->event, EINA_TRUE);
+        evas_object_freeze_events_set(sb->event, EINA_FALSE);
+     }
+}
+
+static void
+_delete_image(void *data, Evas_Object *obj EINA_UNUSED,
+    void *event_info EINA_UNUSED)
+{
+   Ephoto_Single_Browser *sb = data;
+   Evas_Object *popup, *box, *label, *ic, *button;
+
+   if (sb->event)
+     evas_object_freeze_events_set(sb->event, EINA_TRUE);
+
+   popup = elm_popup_add(sb->ephoto->win);
+   elm_object_part_text_set(popup, "title,text", _("Delete File"));
+   elm_popup_orient_set(popup, ELM_POPUP_ORIENT_CENTER);
+
+   box = elm_box_add(popup);
+   elm_box_horizontal_set(box, EINA_FALSE);
+   evas_object_size_hint_weight_set(box, EVAS_HINT_FILL, EVAS_HINT_FILL);
+   evas_object_size_hint_align_set(box, EVAS_HINT_FILL, EVAS_HINT_FILL);
+   evas_object_show(box);
+
+   label = elm_label_add(box);
+   elm_object_text_set(label, _("Are you sure you want to delete this file?"));
+   evas_object_size_hint_weight_set(label, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+   evas_object_size_hint_align_set(label, EVAS_HINT_FILL, EVAS_HINT_FILL);
+   elm_box_pack_end(box, label);
+   evas_object_show(label);
+
+   ic = elm_icon_add(popup);
+   elm_icon_order_lookup_set(ic, ELM_ICON_LOOKUP_FDO_THEME);
+   evas_object_size_hint_aspect_set(ic, EVAS_ASPECT_CONTROL_VERTICAL, 1,
+       1);
+   elm_icon_standard_set(ic, "document-save");
+
+   button = elm_button_add(popup);
+   elm_object_text_set(button, _("Yes"));
+   elm_object_part_content_set(button, "icon", ic);
+   evas_object_smart_callback_add(button, "clicked", _delete_apply,
+       popup);
+   elm_object_part_content_set(popup, "button1", button);
+   evas_object_show(button);
+
+   ic = elm_icon_add(popup);
+   elm_icon_order_lookup_set(ic, ELM_ICON_LOOKUP_FDO_THEME);
+   evas_object_size_hint_aspect_set(ic, EVAS_ASPECT_CONTROL_VERTICAL, 1,
+       1);
+   elm_icon_standard_set(ic, "window-close");
+
+   button = elm_button_add(popup);
+   elm_object_text_set(button, _("No"));
+   elm_object_part_content_set(button, "icon", ic);
+   evas_object_smart_callback_add(button, "clicked", _delete_cancel,
+       popup);
+   elm_object_part_content_set(popup, "button2", button);
+   evas_object_show(button);
+
+   evas_object_data_set(popup, "single_browser", sb);
+   elm_object_part_content_set(popup, "default", box);
+   evas_object_show(popup);
+}
+
+static void
 _go_first(void *data, Evas_Object *obj EINA_UNUSED,
     void *event_info EINA_UNUSED)
 {
@@ -1901,6 +2106,79 @@ _go_old_photo(void *data, Evas_Object *obj EINA_UNUSED,
 }
 
 static void
+_menu_dismissed_cb(void *data, Evas_Object *obj,
+    void *event_info EINA_UNUSED)
+{
+   Ephoto_Single_Browser *sb = data;
+
+   evas_object_del(obj);
+   elm_object_focus_set(sb->event, EINA_TRUE);
+}
+
+static void
+_edit_menu(Ephoto_Single_Browser *sb)
+{
+   Evas_Object *menu, *menu_it;
+   int x, y;
+
+   evas_pointer_canvas_xy_get(evas_object_evas_get(sb->main), &x, &y);
+   menu = elm_menu_add(sb->main);
+   elm_menu_move(menu, x, y);
+   elm_menu_item_add(menu, NULL, "edit-undo", _("Reset"), _reset_image, sb);
+   elm_menu_item_add(menu, NULL, "document-save", _("Save"), _save_image, sb);
+   elm_menu_item_add(menu, NULL, "document-save-as", _("Save As"),
+       _save_image_as, sb);
+   elm_menu_item_add(menu, NULL, "document-send", _("Upload"), _upload_image,
+       sb);
+   elm_menu_item_add(menu, NULL, "edit-delete", _("Delete"),
+            _delete_image, sb);
+   elm_menu_item_separator_add(menu, NULL);
+
+   menu_it =
+       elm_menu_item_add(menu, NULL, "document-properties", _("Transform"),
+       NULL, NULL);
+   elm_menu_item_add(menu, menu_it, "edit-cut", _("Crop"), _crop_image, sb);
+   elm_menu_item_separator_add(menu, menu_it);
+   elm_menu_item_add(menu, menu_it, "object-rotate-left", _("Rotate Left"),
+       _go_rotate_counterclock, sb);
+   elm_menu_item_add(menu, menu_it, "object-rotate-right", _("Rotate Right"),
+       _go_rotate_clock, sb);
+   elm_menu_item_add(menu, menu_it, "object-flip-horizontal",
+       _("Flip Horizontal"), _go_flip_horiz, sb);
+   elm_menu_item_add(menu, menu_it, "object-flip-vertical", _("Flip Vertical"),
+       _go_flip_vert, sb);
+   elm_menu_item_separator_add(menu, NULL);
+
+   menu_it =
+       elm_menu_item_add(menu, NULL, "document-properties", _("Color"), NULL,
+       NULL);
+   elm_menu_item_add(menu, menu_it, "insert-image", _("Auto Equalize"),
+       _go_auto_eq, sb);
+   elm_menu_item_separator_add(menu, menu_it);
+   elm_menu_item_add(menu, menu_it, "insert-image",
+       _("Brightness/Contrast/Gamma"), _go_bcg, sb);
+   elm_menu_item_add(menu, menu_it, "insert-image", _("Hue/Saturation/Value"),
+       _go_hsv, sb);
+   elm_menu_item_add(menu, menu_it, "insert-image", _("Color Levels"),
+       _go_color, sb);
+
+   menu_it =
+       elm_menu_item_add(menu, NULL, "document-properties", _("Filters"), NULL,
+       NULL);
+   elm_menu_item_add(menu, menu_it, "insert-image", _("Blur"), _go_blur, sb);
+   elm_menu_item_add(menu, menu_it, "insert-image", _("Sharpen"), _go_sharpen,
+       sb);
+   elm_menu_item_separator_add(menu, menu_it);
+   elm_menu_item_add(menu, menu_it, "insert-image", _("Black and White"),
+       _go_black_and_white, sb);
+   elm_menu_item_add(menu, menu_it, "insert-image", _("Old Photo"),
+       _go_old_photo, sb);
+   evas_object_smart_callback_add(menu, "dismissed", _menu_dismissed_cb,
+       sb);
+   evas_object_show(menu);
+}
+
+static void
 _slideshow(void *data, Evas_Object *obj EINA_UNUSED,
     void *event_info EINA_UNUSED)
 {
@@ -2292,6 +2570,8 @@ ephoto_single_browser_add(Ephoto *ephoto, Evas_Object 
*parent)
        _save_image_as, sb);
    elm_menu_item_add(menu, NULL, "document-send", _("Upload"), _upload_image,
        sb);
+   elm_menu_item_add(menu, NULL, "edit-delete", _("Delete"),
+            _delete_image, sb);
    elm_menu_item_separator_add(menu, NULL);
 
    menu_it =
diff --git a/src/bin/ephoto_thumb_browser.c b/src/bin/ephoto_thumb_browser.c
index 2648cc3..8b1fe55 100644
--- a/src/bin/ephoto_thumb_browser.c
+++ b/src/bin/ephoto_thumb_browser.c
@@ -43,6 +43,7 @@ struct _Ephoto_Thumb_Browser
    Eina_List *todo_items;
    Ecore_Idler *idler;
    Ecore_Job *change_dir_job;
+   Ecore_Timer *click_timer;
    int thumbs_only;
    int dirs_only;
    int totimages;
@@ -82,6 +83,8 @@ _on_list_expand_req(void *data, Evas_Object *obj EINA_UNUSED,
 
    ecore_job_del(tb->change_dir_job);
    tb->change_dir_job = NULL;
+   ecore_timer_del(tb->click_timer);
+   tb->click_timer = NULL;
    elm_genlist_item_expanded_set(it, EINA_TRUE);
 }
 
@@ -94,6 +97,8 @@ _on_list_contract_req(void *data EINA_UNUSED, Evas_Object 
*obj EINA_UNUSED,
 
    ecore_job_del(tb->change_dir_job);
    tb->change_dir_job = NULL;
+   ecore_timer_del(tb->click_timer);
+   tb->click_timer = NULL;
    elm_genlist_item_expanded_set(it, EINA_FALSE);
 }
 
@@ -125,24 +130,19 @@ _on_list_contracted(void *data, Evas_Object *obj 
EINA_UNUSED, void *event_info)
    const char *path = elm_object_item_data_get(it);
 
    elm_genlist_item_subitems_clear(it); 
-   tb->dirs_only = 0;
-   tb->thumbs_only = 1;
    if (strlen(path) == strlen(tb->ephoto->config->directory))
      {
        if (!strcmp(path, tb->ephoto->config->directory))
           {
              return;
           }
-        else
-          {
-             tb->thumbs_only = 1;
-             tb->dirs_only = 0;
-             ephoto_directory_set(tb->ephoto, path, NULL,
-                 tb->dirs_only, tb->thumbs_only);
-             ephoto_title_set(tb->ephoto,
-                 tb->ephoto->config->directory);
-          }
      }
+   tb->thumbs_only = 1;
+   tb->dirs_only = 0;
+   ephoto_directory_set(tb->ephoto, path, NULL,
+       tb->dirs_only, tb->thumbs_only);
+   ephoto_title_set(tb->ephoto,
+       tb->ephoto->config->directory);
 }
 
 static void
@@ -786,6 +786,7 @@ _ephoto_dir_hide_folders(void *data, Evas_Object *obj 
EINA_UNUSED,
    tb->ficon = elm_toolbar_item_prepend(tb->bar, "system-file-manager", 
_("Folders"),
        _ephoto_dir_show_folders, tb);
 
+   elm_object_focus_set(tb->main, EINA_TRUE);
    tb->ephoto->config->fsel_hide = 1;
 }
 
@@ -2702,6 +2703,20 @@ _menu_dismissed_cb(void *data, Evas_Object *obj,
    elm_object_focus_set(tb->main, EINA_TRUE);
 }
 
+static Eina_Bool
+_click_timer_cb(void *data)
+{
+   Elm_Object_Item *item = data;
+   Ephoto_Thumb_Browser *tb = evas_object_data_get(item, "thumb_browser");
+
+   printf("No\n");
+
+   _on_list_selected(tb, NULL, item);
+   tb->click_timer = NULL;
+
+   return ECORE_CALLBACK_CANCEL;
+}
+
 static void
 _fsel_mouse_up_cb(void *data, Evas *e EINA_UNUSED, Evas_Object *obj 
EINA_UNUSED,
     void *event_info)
@@ -2715,9 +2730,31 @@ _fsel_mouse_up_cb(void *data, Evas *e EINA_UNUSED, 
Evas_Object *obj EINA_UNUSED,
 
    evas_pointer_canvas_xy_get(evas_object_evas_get(tb->fsel), &x, &y);
    item = elm_genlist_at_xy_item_get(tb->fsel, x, y, 0);
-   if (info->button == 1 && item)
-     _on_list_selected(tb, NULL, item);
 
+   if (info->button == 1 && item)
+     {
+        if (info->flags == EVAS_BUTTON_DOUBLE_CLICK)
+          {
+             if (elm_genlist_item_type_get(item) == ELM_GENLIST_ITEM_TREE)
+               {
+                  if (tb->click_timer)
+                    {
+                       ecore_timer_del(tb->click_timer);
+                       tb->click_timer = NULL;
+                       elm_genlist_item_expanded_set(item,
+                           !elm_genlist_item_expanded_get(item));
+                    }
+               }
+          }
+        else
+          {
+             evas_object_data_set(item, "thumb_browser", tb);
+             if (elm_genlist_item_type_get(item) == ELM_GENLIST_ITEM_TREE)
+               tb->click_timer = ecore_timer_add(.3, _click_timer_cb, item);
+             else
+               _on_list_selected(tb, NULL, item);
+          }
+     }
    if (info->button != 3)
      return;
 
@@ -2867,11 +2904,22 @@ _key_down(void *data, Evas *e EINA_UNUSED, Evas_Object 
*obj EINA_UNUSED,
    Ephoto_Thumb_Browser *tb = data;
    Evas_Event_Key_Down *ev = event_info;
    Eina_Bool ctrl = evas_key_modifier_is_set(ev->modifiers, "Control");
+   Eina_Bool shift = evas_key_modifier_is_set(ev->modifiers, "Shift");
    const char *k = ev->keyname;
    
    if (ctrl)
      {
-       if ((!strcmp(k, "plus")) || (!strcmp(k, "equal")))
+        if (shift)
+          {
+             if (!strcmp(k, "f"))
+               {
+                  if (evas_object_visible_get(tb->leftbox))
+                    _ephoto_dir_hide_folders(tb, NULL, NULL);
+                  else
+                    _ephoto_dir_show_folders(tb, NULL, NULL);
+               }
+          }
+       else if ((!strcmp(k, "plus")) || (!strcmp(k, "equal")))
          {
             int zoom = tb->ephoto->config->thumb_size + ZOOM_STEP;
 
@@ -2913,11 +2961,11 @@ _key_down(void *data, Evas *e EINA_UNUSED, Evas_Object 
*obj EINA_UNUSED,
              _grid_menu_select_all_cb(tb, NULL, NULL);
           }
      }
-   if (!strcmp(k, "F1"))
+   else if (!strcmp(k, "F1"))
      {
         _settings(tb, NULL, NULL);
      }
-   if (!strcmp(k, "F2"))
+   else if (!strcmp(k, "F2"))
      {
         Elm_Object_Item *it = NULL;
 
@@ -2929,7 +2977,7 @@ _key_down(void *data, Evas *e EINA_UNUSED, Evas_Object 
*obj EINA_UNUSED,
              _grid_menu_rename_cb(it, NULL, NULL);
           }
      }
-   if (!strcmp(k, "F5"))
+   else if (!strcmp(k, "F5"))
      {
        Elm_Object_Item *it = elm_gengrid_selected_item_get(tb->grid);
        Ephoto_Entry *entry;

-- 


Reply via email to