tizen 2.4 release
[framework/uifw/elementary.git] / src / lib / elc_fileselector_button.c
index be822d5..a1a7c1a 100644 (file)
@@ -1,52 +1,60 @@
+#ifdef HAVE_CONFIG_H
+# include "elementary_config.h"
+#endif
+
+#define ELM_INTERFACE_ATSPI_ACCESSIBLE_PROTECTED
+
 #include <Elementary.h>
 #include "elm_priv.h"
+#include "elm_interface_fileselector.h"
 #include "elm_widget_fileselector_button.h"
 
-EAPI const char ELM_FILESELECTOR_BUTTON_SMART_NAME[] =
-  "elm_fileselector_button";
+#define MY_CLASS ELM_FILESELECTOR_BUTTON_CLASS
+
+#define MY_CLASS_NAME "Elm_Fileselector_Button"
+#define MY_CLASS_NAME_LEGACY "elm_fileselector_button"
+
+/* FIXME: need a way to find a gap between the size of item and thumbnail */
+#define GENGRID_PADDING 16
 
 #define DEFAULT_WINDOW_TITLE "Select a file"
 
-static const char SIG_FILE_CHOSEN[] = "file,chosen";
-static const char SIG_LANG_CHANGED[] = "language,changed";
+#define ELM_PRIV_FILESELECTOR_BUTTON_SIGNALS(cmd) \
+   cmd(SIG_FILE_CHOSEN, "file,chosen", "s") \
+
+ELM_PRIV_FILESELECTOR_BUTTON_SIGNALS(ELM_PRIV_STATIC_VARIABLE_DECLARE);
 
 static const Evas_Smart_Cb_Description _smart_callbacks[] = {
-   {SIG_FILE_CHOSEN, "s"},
-   {SIG_LANG_CHANGED, ""},
+   ELM_PRIV_FILESELECTOR_BUTTON_SIGNALS(ELM_PRIV_SMART_CALLBACKS_DESC)
+   {SIG_WIDGET_LANG_CHANGED, ""}, /**<handled by elm_widget */
+   {SIG_WIDGET_ACCESS_CHANGED, ""}, /**<handled by elm_widget */
+   {SIG_LAYOUT_FOCUSED, ""}, /**< handled by elm_layout */
+   {SIG_LAYOUT_UNFOCUSED, ""}, /**< handled by elm_layout */
    {NULL, NULL}
 };
+#undef ELM_PRIV_FILESELECTOR_BUTTON_SIGNALS
 
-EVAS_SMART_SUBCLASS_NEW
-  (ELM_FILESELECTOR_BUTTON_SMART_NAME, _elm_fileselector_button,
-  Elm_Fileselector_Button_Smart_Class, Elm_Button_Smart_Class,
-  elm_button_smart_class_get, _smart_callbacks);
-
-static Eina_Bool
-_elm_fileselector_button_smart_translate(Evas_Object *obj)
+EOLIAN static Eina_Bool
+_elm_fileselector_button_elm_widget_theme_apply(Eo *obj, Elm_Fileselector_Button_Data *sd EINA_UNUSED)
 {
-   evas_object_smart_callback_call(obj, SIG_LANG_CHANGED, NULL);
-   return EINA_TRUE;
-}
+   Eina_Bool int_ret = EINA_FALSE;
 
-static Eina_Bool
-_elm_fileselector_button_smart_theme(Evas_Object *obj)
-{
    char buf[4096];
    const char *style;
 
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   ELM_WIDGET_DATA_GET_OR_RETURN(obj, wd, EINA_FALSE);
 
    style = eina_stringshare_add(elm_widget_style_get(obj));
 
    snprintf(buf, sizeof(buf), "fileselector_button/%s", style);
 
    /* file selector button's style has an extra bit */
-   eina_stringshare_replace(&(ELM_WIDGET_DATA(sd)->style), buf);
+   eina_stringshare_replace(&(wd->style), buf);
 
-   if (!ELM_WIDGET_CLASS(_elm_fileselector_button_parent_sc)->theme(obj))
-     return EINA_FALSE;
+   eo_do_super(obj, MY_CLASS, int_ret = elm_obj_widget_theme_apply());
+   if (!int_ret) return EINA_FALSE;
 
-   eina_stringshare_replace(&(ELM_WIDGET_DATA(sd)->style), style);
+   eina_stringshare_replace(&(wd->style), style);
 
    eina_stringshare_del(style);
 
@@ -55,10 +63,10 @@ _elm_fileselector_button_smart_theme(Evas_Object *obj)
 
 static void
 _selection_done(void *data,
-                Evas_Object *obj __UNUSED__,
+                Evas_Object *obj EINA_UNUSED,
                 void *event_info)
 {
-   Elm_Fileselector_Button_Smart_Data *sd = data;
+   Elm_Fileselector_Button_Data *sd = data;
    const char *file = event_info;
    Evas_Object *del;
 
@@ -70,11 +78,11 @@ _selection_done(void *data,
    evas_object_del(del);
 
    evas_object_smart_callback_call
-     (ELM_WIDGET_DATA(sd)->obj, SIG_FILE_CHOSEN, (void *)file);
+     (sd->obj, SIG_FILE_CHOSEN, (void *)file);
 }
 
 static Evas_Object *
-_new_window_add(Elm_Fileselector_Button_Smart_Data *sd)
+_new_window_add(Elm_Fileselector_Button_Data *sd)
 {
    Evas_Object *win, *bg;
 
@@ -95,14 +103,14 @@ _new_window_add(Elm_Fileselector_Button_Smart_Data *sd)
 static Evas_Object *
 _parent_win_get(Evas_Object *obj)
 {
-   while ((obj) && (strcmp(elm_widget_type_get(obj), "elm_win")))
+   while ((obj) && (strcmp(evas_object_type_get(obj), "elm_win")))
      obj = elm_object_parent_widget_get(obj);
 
    return obj;
 }
 
 static void
-_activate(Elm_Fileselector_Button_Smart_Data *sd)
+_activate(Elm_Fileselector_Button_Data *sd)
 {
    Eina_Bool is_inwin = EINA_FALSE;
 
@@ -110,7 +118,7 @@ _activate(Elm_Fileselector_Button_Smart_Data *sd)
 
    if (sd->inwin_mode)
      {
-        sd->fsw = _parent_win_get(ELM_WIDGET_DATA(sd)->obj);
+        sd->fsw = _parent_win_get(sd->obj);
 
         if (!sd->fsw)
           sd->fsw = _new_window_add(sd);
@@ -125,7 +133,7 @@ _activate(Elm_Fileselector_Button_Smart_Data *sd)
 
    sd->fs = elm_fileselector_add(sd->fsw);
    elm_widget_mirrored_set
-     (sd->fs, elm_widget_mirrored_get(ELM_WIDGET_DATA(sd)->obj));
+     (sd->fs, elm_widget_mirrored_get(sd->obj));
    elm_widget_mirrored_automatic_set(sd->fs, EINA_FALSE);
    elm_fileselector_expandable_set(sd->fs, sd->fsd.expandable);
    elm_fileselector_folder_only_set(sd->fs, sd->fsd.folder_only);
@@ -151,253 +159,352 @@ _activate(Elm_Fileselector_Button_Smart_Data *sd)
 
 static void
 _button_clicked(void *data,
-                Evas_Object *obj __UNUSED__,
-                void *event_info __UNUSED__)
+                Evas_Object *obj EINA_UNUSED,
+                void *event_info EINA_UNUSED)
 {
    _activate(data);
 }
 
-static void
-_elm_fileselector_button_smart_add(Evas_Object *obj)
+EOLIAN static void
+_elm_fileselector_button_evas_object_smart_add(Eo *obj, Elm_Fileselector_Button_Data *priv)
 {
-   EVAS_SMART_DATA_ALLOC(obj, Elm_Fileselector_Button_Smart_Data);
+   eo_do_super(obj, MY_CLASS, evas_obj_smart_add());
+   elm_widget_sub_object_parent_add(obj);
 
-   ELM_WIDGET_CLASS(_elm_fileselector_button_parent_sc)->base.add(obj);
-}
+   priv->window_title = eina_stringshare_add(DEFAULT_WINDOW_TITLE);
+   if (getenv("HOME")) priv->fsd.path = eina_stringshare_add(getenv("HOME"));
+   else priv->fsd.path = eina_stringshare_add("/");
 
-static void
-_elm_fileselector_button_smart_del(Evas_Object *obj)
-{
-   Evas_Object *win;
+   priv->fsd.expandable = _elm_config->fileselector_expand_enable;
+   priv->inwin_mode = _elm_config->inwin_dialogs_enable;
+   priv->w = 400;
+   priv->h = 400;
 
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   elm_widget_mirrored_automatic_set(obj, EINA_FALSE);
 
-   if (sd->window_title) eina_stringshare_del(sd->window_title);
-   if (sd->fsd.path) eina_stringshare_del(sd->fsd.path);
-   if (sd->fs)
-     {
-        win = evas_object_data_del(obj, "win");
-        evas_object_del(win);
-     }
+   evas_object_smart_callback_add(obj, "clicked", _button_clicked, priv);
 
-   ELM_WIDGET_CLASS(_elm_fileselector_button_parent_sc)->base.del(obj);
+   eo_do(obj, elm_obj_widget_theme_apply());
+   elm_widget_can_focus_set(obj, EINA_TRUE);
 }
 
-static void
-_elm_fileselector_button_smart_set_user(
-  Elm_Fileselector_Button_Smart_Class *sc)
+EOLIAN static void
+_elm_fileselector_button_evas_object_smart_del(Eo *obj, Elm_Fileselector_Button_Data *sd)
 {
-   ELM_WIDGET_CLASS(sc)->base.add = _elm_fileselector_button_smart_add;
-   ELM_WIDGET_CLASS(sc)->base.del = _elm_fileselector_button_smart_del;
+   eina_stringshare_del(sd->window_title);
+   eina_stringshare_del(sd->fsd.path);
+   eina_stringshare_del(sd->fsd.selection);
+   evas_object_del(sd->fsw);
 
-   ELM_WIDGET_CLASS(sc)->theme = _elm_fileselector_button_smart_theme;
-   ELM_WIDGET_CLASS(sc)->translate = _elm_fileselector_button_smart_translate;
-
-   ELM_BUTTON_CLASS(sc)->admits_autorepeat = EINA_FALSE;
+   eo_do_super(obj, MY_CLASS, evas_obj_smart_del());
 }
 
-EAPI const Elm_Fileselector_Button_Smart_Class *
-elm_fileselector_button_smart_class_get(void)
+EOLIAN static Eina_Bool
+_elm_fileselector_button_elm_button_admits_autorepeat_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd EINA_UNUSED)
 {
-   static Elm_Fileselector_Button_Smart_Class _sc =
-     ELM_FILESELECTOR_BUTTON_SMART_CLASS_INIT_NAME_VERSION
-       (ELM_FILESELECTOR_BUTTON_SMART_NAME);
-   static const Elm_Fileselector_Button_Smart_Class *class = NULL;
-   Evas_Smart_Class *esc = (Evas_Smart_Class *)&_sc;
-
-   if (class) return class;
-
-   _elm_fileselector_button_smart_set(&_sc);
-   esc->callbacks = _smart_callbacks;
-   class = &_sc;
-
-   return class;
+   return EINA_FALSE;
 }
 
 EAPI Evas_Object *
 elm_fileselector_button_add(Evas_Object *parent)
 {
-   Evas_Object *obj;
-
    EINA_SAFETY_ON_NULL_RETURN_VAL(parent, NULL);
-
-   obj = elm_widget_add(_elm_fileselector_button_smart_class_new(), parent);
-   if (!obj) return NULL;
-
-   if (!elm_widget_sub_object_add(parent, obj))
-     ERR("could not add %p as sub object of %p", obj, parent);
-
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
-
-   sd->window_title = eina_stringshare_add(DEFAULT_WINDOW_TITLE);
-   if (getenv("HOME")) sd->fsd.path = eina_stringshare_add(getenv("HOME"));
-   else sd->fsd.path = eina_stringshare_add("/");
-
-   sd->fsd.expandable = _elm_config->fileselector_expand_enable;
-   sd->inwin_mode = _elm_config->inwin_dialogs_enable;
-   sd->w = 400;
-   sd->h = 400;
-
-   elm_widget_mirrored_automatic_set(obj, EINA_FALSE);
-
-   evas_object_smart_callback_add(obj, "clicked", _button_clicked, sd);
-
-   _elm_fileselector_button_smart_theme(obj);
-   elm_widget_can_focus_set(obj, EINA_TRUE);
-
-   //Tizen Only: This should be removed when eo is applied.
-   ELM_WIDGET_DATA_GET(obj, wsd);
-   wsd->on_create = EINA_FALSE;
-
+   Evas_Object *obj = eo_add(MY_CLASS, parent);
    return obj;
 }
 
-EAPI void
-elm_fileselector_button_window_title_set(Evas_Object *obj,
-                                         const char *title)
+EOLIAN static void
+_elm_fileselector_button_eo_base_constructor(Eo *obj, Elm_Fileselector_Button_Data *sd)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj);
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   sd->obj = obj;
+
+   eo_do_super(obj, MY_CLASS, eo_constructor());
+   eo_do(obj,
+         evas_obj_type_set(MY_CLASS_NAME_LEGACY),
+         evas_obj_smart_callbacks_descriptions_set(_smart_callbacks),
+         elm_interface_atspi_accessible_role_set(ELM_ATSPI_ROLE_PUSH_BUTTON));
+}
 
+EOLIAN static void
+_elm_fileselector_button_window_title_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, const char *title)
+{
    eina_stringshare_replace(&sd->window_title, title);
 
    if (sd->fsw) elm_win_title_set(sd->fsw, sd->window_title);
 }
 
-EAPI const char *
-elm_fileselector_button_window_title_get(const Evas_Object *obj)
+EOLIAN static const char *
+_elm_fileselector_button_window_title_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj) NULL;
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
-
    return sd->window_title;
 }
 
-EAPI void
-elm_fileselector_button_window_size_set(Evas_Object *obj,
-                                        Evas_Coord width,
-                                        Evas_Coord height)
+EOLIAN static void
+_elm_fileselector_button_window_size_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, Evas_Coord width, Evas_Coord height)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj);
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
-
    sd->w = width;
    sd->h = height;
 
    if (sd->fsw) evas_object_resize(sd->fsw, sd->w, sd->h);
 }
 
-EAPI void
-elm_fileselector_button_window_size_get(const Evas_Object *obj,
-                                        Evas_Coord *width,
-                                        Evas_Coord *height)
+EOLIAN static void
+_elm_fileselector_button_window_size_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, Evas_Coord *width, Evas_Coord *height)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj);
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
-
    if (width) *width = sd->w;
    if (height) *height = sd->h;
 }
 
-EAPI void
+EINA_DEPRECATED EAPI void
 elm_fileselector_button_path_set(Evas_Object *obj,
                                  const char *path)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj);
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   ELM_FILESELECTOR_INTERFACE_CHECK(obj);
+   eo_do(obj, elm_interface_fileselector_path_set(path));
+}
 
+EOLIAN static void
+_elm_fileselector_button_elm_interface_fileselector_path_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, const char *path)
+{
    eina_stringshare_replace(&sd->fsd.path, path);
 
    if (sd->fs) elm_fileselector_selected_set(sd->fs, sd->fsd.path);
 }
 
-EAPI const char *
+EINA_DEPRECATED EAPI const char *
 elm_fileselector_button_path_get(const Evas_Object *obj)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj) NULL;
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   ELM_FILESELECTOR_INTERFACE_CHECK(obj, NULL);
+   const char *ret = NULL;
+   eo_do((Eo *) obj, ret = elm_interface_fileselector_path_get());
+   return ret;
+}
 
+EOLIAN static const char *
+_elm_fileselector_button_elm_interface_fileselector_path_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd)
+{
    return sd->fsd.path;
 }
 
-EAPI void
+EINA_DEPRECATED EAPI void
 elm_fileselector_button_expandable_set(Evas_Object *obj,
                                        Eina_Bool value)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj);
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   ELM_FILESELECTOR_INTERFACE_CHECK(obj);
+   eo_do(obj, elm_interface_fileselector_expandable_set(value));
+}
 
+EOLIAN static void
+_elm_fileselector_button_elm_interface_fileselector_expandable_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, Eina_Bool value)
+{
    sd->fsd.expandable = value;
 
    if (sd->fs) elm_fileselector_expandable_set(sd->fs, sd->fsd.expandable);
 }
 
-EAPI Eina_Bool
+EINA_DEPRECATED EAPI Eina_Bool
 elm_fileselector_button_expandable_get(const Evas_Object *obj)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj) EINA_FALSE;
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   ELM_FILESELECTOR_INTERFACE_CHECK(obj, EINA_FALSE);
+   Eina_Bool ret = EINA_FALSE;
+   eo_do((Eo *) obj, ret = elm_interface_fileselector_expandable_get());
+   return ret;
+}
 
+EOLIAN static Eina_Bool
+_elm_fileselector_button_elm_interface_fileselector_expandable_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd)
+{
    return sd->fsd.expandable;
 }
 
-EAPI void
+EINA_DEPRECATED EAPI void
 elm_fileselector_button_folder_only_set(Evas_Object *obj,
                                         Eina_Bool value)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj);
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   ELM_FILESELECTOR_INTERFACE_CHECK(obj);
+   eo_do(obj, elm_interface_fileselector_folder_only_set(value));
+}
 
+EOLIAN static void
+_elm_fileselector_button_elm_interface_fileselector_folder_only_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, Eina_Bool value)
+{
    sd->fsd.folder_only = value;
 
    if (sd->fs) elm_fileselector_folder_only_set(sd->fs, sd->fsd.folder_only);
 }
 
-EAPI Eina_Bool
+EINA_DEPRECATED EAPI Eina_Bool
 elm_fileselector_button_folder_only_get(const Evas_Object *obj)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj) EINA_FALSE;
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   ELM_FILESELECTOR_INTERFACE_CHECK(obj, EINA_FALSE);
+   Eina_Bool ret = EINA_FALSE;
+   eo_do((Eo *) obj, ret = elm_interface_fileselector_folder_only_get());
+   return ret;
+}
 
+EOLIAN static Eina_Bool
+_elm_fileselector_button_elm_interface_fileselector_folder_only_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd)
+{
    return sd->fsd.folder_only;
 }
 
-EAPI void
+EINA_DEPRECATED EAPI void
 elm_fileselector_button_is_save_set(Evas_Object *obj,
                                     Eina_Bool value)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj);
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   ELM_FILESELECTOR_INTERFACE_CHECK(obj);
+   eo_do(obj, elm_interface_fileselector_is_save_set(value));
+}
 
+EOLIAN static void
+_elm_fileselector_button_elm_interface_fileselector_is_save_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, Eina_Bool value)
+{
    sd->fsd.is_save = value;
 
    if (sd->fs) elm_fileselector_is_save_set(sd->fs, sd->fsd.is_save);
 }
 
-EAPI Eina_Bool
+EINA_DEPRECATED EAPI Eina_Bool
 elm_fileselector_button_is_save_get(const Evas_Object *obj)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj) EINA_FALSE;
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   ELM_FILESELECTOR_INTERFACE_CHECK(obj, EINA_FALSE);
+   Eina_Bool ret = EINA_FALSE;
+   eo_do((Eo *) obj, ret = elm_interface_fileselector_is_save_get());
+   return ret;
+}
 
+EOLIAN static Eina_Bool
+_elm_fileselector_button_elm_interface_fileselector_is_save_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd)
+{
    return sd->fsd.is_save;
 }
 
-EAPI void
-elm_fileselector_button_inwin_mode_set(Evas_Object *obj,
-                                       Eina_Bool value)
+EOLIAN static void
+_elm_fileselector_button_elm_interface_fileselector_mode_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, Elm_Fileselector_Mode mode)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj);
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   sd->fsd.mode = mode;
 
-   sd->inwin_mode = value;
+   if (sd->fs) elm_fileselector_mode_set(sd->fs, mode);
+}
+
+EOLIAN static Elm_Fileselector_Mode
+_elm_fileselector_button_elm_interface_fileselector_mode_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd)
+{
+   return sd->fsd.mode;
+}
+
+EOLIAN static void
+_elm_fileselector_button_elm_interface_fileselector_sort_method_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, Elm_Fileselector_Sort sort)
+{
+   sd->fsd.sort_type = sort;
+
+   if (sd->fs) elm_fileselector_sort_method_set(sd->fs, sort);
+}
+
+EOLIAN static Elm_Fileselector_Sort
+_elm_fileselector_button_elm_interface_fileselector_sort_method_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd)
+{
+   return sd->fsd.sort_type;
+}
+
+EOLIAN static void
+_elm_fileselector_button_elm_interface_fileselector_multi_select_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, Eina_Bool value)
+{
+   sd->fsd.multi = value;
+
+   if (sd->fs) elm_fileselector_multi_select_set(sd->fs, sd->fsd.multi);
+}
+
+EOLIAN static Eina_Bool
+_elm_fileselector_button_elm_interface_fileselector_multi_select_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd)
+{
+   return sd->fsd.multi;
+}
+
+EOLIAN static const Eina_List*
+_elm_fileselector_button_elm_interface_fileselector_selected_paths_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd)
+{
+   if (sd->fs) return elm_fileselector_selected_paths_get(sd->fs);
+
+   return NULL;
+}
+
+EOLIAN static const char*
+_elm_fileselector_button_elm_interface_fileselector_selected_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd)
+{
+   if (sd->fs) return elm_fileselector_selected_get(sd->fs);
+
+   return sd->fsd.selection;
+}
+
+EOLIAN static Eina_Bool
+_elm_fileselector_button_elm_interface_fileselector_selected_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, const char *_path)
+{
+   Eina_Bool ret = EINA_TRUE;
+
+   if (sd->fs) ret = elm_fileselector_selected_set(sd->fs, _path);
+   else
+     {
+        char *path = ecore_file_realpath(_path);
+        if (!ecore_file_is_dir(path) && !ecore_file_exists(path))
+          {
+             free(path);
+             return EINA_FALSE;
+          }
+        free(path);
+     }
+
+   eina_stringshare_replace(&sd->fsd.selection, _path);
+
+   return ret;
 }
 
-EAPI Eina_Bool
-elm_fileselector_button_inwin_mode_get(const Evas_Object *obj)
+EOLIAN static void
+_elm_fileselector_button_elm_interface_fileselector_thumbnail_size_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, Evas_Coord w, Evas_Coord h)
 {
-   ELM_FILESELECTOR_BUTTON_CHECK(obj) EINA_FALSE;
-   ELM_FILESELECTOR_BUTTON_DATA_GET(obj, sd);
+   if (sd->fs)
+     {
+        elm_fileselector_thumbnail_size_set(sd->fs, w, h);
+        elm_fileselector_thumbnail_size_get(sd->fs, &w, &h);
+     }
+   else if (!w || !h)
+     w = h = elm_config_finger_size_get() * 2 - GENGRID_PADDING;
 
+   sd->fsd.thumbnail_size.w = w;
+   sd->fsd.thumbnail_size.h = h;
+}
+
+EOLIAN static void
+_elm_fileselector_button_elm_interface_fileselector_thumbnail_size_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, Evas_Coord *w, Evas_Coord *h)
+{
+   if (w) *w = sd->fsd.thumbnail_size.w;
+   if (h) *h = sd->fsd.thumbnail_size.h;
+}
+
+EOLIAN static void
+_elm_fileselector_button_elm_interface_fileselector_hidden_visible_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, Eina_Bool visible)
+{
+   sd->fsd.hidden_visible = visible;
+
+   if (sd->fs) elm_fileselector_hidden_visible_set(sd->fs, visible);
+}
+
+EOLIAN static Eina_Bool
+_elm_fileselector_button_elm_interface_fileselector_hidden_visible_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd)
+{
+   return sd->fsd.hidden_visible;
+}
+
+EOLIAN static void
+_elm_fileselector_button_inwin_mode_set(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd, Eina_Bool value)
+{
+   sd->inwin_mode = value;
+}
+
+EOLIAN static Eina_Bool
+_elm_fileselector_button_inwin_mode_get(Eo *obj EINA_UNUSED, Elm_Fileselector_Button_Data *sd)
+{
    return sd->inwin_mode;
 }
+
+#include "elm_fileselector_button.eo.c"