- add hilite propagation (single click file, press ok is now the same as double clicking the file directly)
- eap editor saves new eaps if you give them a path, simple <-> advanced doesnt relay the info between each other yet.
Going to try to do a bit every night.
SVN revision: 18849
static Evas_Object *_e_eap_edit_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, void *data);
static Evas_Object *_e_eap_edit_advanced_create_widgets(E_Config_Dialog *cfd, Evas *evas, void *data);
static void _e_eap_edit_select_cb(Evas_Object *obj, char *file, void *data);
+static void _e_eap_edit_hilite_cb(Evas_Object *obj, char *file, void *data);
#define IFDUP(src, dst) if (src) dst = strdup(src); else dst = NULL
editor->img_widget = e_widget_iconsel_add(evas, editor->img, 48, 48,
&(cfdata->image));
e_widget_iconsel_select_callback_add(editor->img_widget, _e_eap_edit_select_cb, editor);
+ e_widget_iconsel_hilite_callback_add(editor->img_widget, _e_eap_edit_hilite_cb, editor);
e_widget_frametable_object_append(o, editor->img_widget,
0, 0, 1, 1,
1, 1, 1, 1);
printf("selected: %s\n", file);
}
+
+void
+_e_eap_edit_hilite_cb(Evas_Object *obj, char *file, void *data)
+{
+ E_App_Edit *editor;
+
+// editor = data;
+ printf("hilited: %s\n", file);
+
+}
static void _e_file_dialog_button2_click(void *data, E_Dialog *dia);
static void _e_file_dialog_free(E_File_Dialog *dia);
static void _e_file_dialog_file_select_cb(Evas_Object *obj, char *file, void *data);
+static void _e_file_dialog_file_hilite_cb(Evas_Object *obj, char *file, void *data);
E_File_Dialog *
e_file_dialog_new(E_Container *con)
dia->con = con;
dia->file = NULL;
dia->select_func = NULL;
+ dia->hilite_func = NULL;
dia->select_data = NULL;
evas = dia->dia->win->evas;
fm = e_widget_fileman_add(evas, &(dia->file));
e_widget_fileman_select_callback_add(fm, _e_file_dialog_file_select_cb, dia);
+ e_widget_fileman_hilite_callback_add(fm, _e_file_dialog_file_hilite_cb, dia);
e_widget_list_object_append(ol, fm, 1, 1, 0.0);
e_widget_min_size_get(ol, &w, &h);
dia->select_data = data;
}
+void
+e_file_dialog_hilite_callback_add(E_File_Dialog *dia, void (*func)(E_File_Dialog *dia, char *file, void *data), void *data)
+{
+ dia->hilite_func = func;
+ dia->hilite_data = data;
+}
+
/* local subsystem functions */
static void
dia = data;
if(dia->select_func && dia->file)
dia->select_func(dia, dia->file, dia->select_data);
- _e_file_dialog_free(dia);
+ _e_file_dialog_free(dia);
}
static void
if(dia->select_func)
dia->select_func(dia, file, dia->select_data);
- printf("e_file_dialog: %s\n", file);
+ printf("e_file_dialog (select) : %s\n", file);
+
+}
+
+static void
+_e_file_dialog_file_hilite_cb(Evas_Object *obj, char *file, void *data)
+{
+ E_File_Dialog *dia;
+
+ dia = data;
+ if(dia->hilite_func)
+ dia->hilite_func(dia, file, dia->hilite_data);
+ printf("e_file_dialog (hilite) : %s\n", file);
}
static void
{
e_object_unref(E_OBJECT(dia->dia));
E_FREE(dia->file);
- free(dia);
+ //free(dia);
}
void (*select_func)(E_File_Dialog *dia, char *file, void *data);
void *select_data;
+ void (*hilite_func)(E_File_Dialog *dia, char *file, void *data);
+ void *hilite_data;
};
EAPI E_File_Dialog *e_file_dialog_new (E_Container *con);
EAPI void e_file_dialog_show (E_File_Dialog *dia);
EAPI void e_file_dialog_title_set (E_File_Dialog *dia, const char *title);
EAPI void e_file_dialog_select_callback_add(E_File_Dialog *dia, void (*func)(E_File_Dialog *dia, char *file, void *data), void *data);
+EAPI void e_file_dialog_hilite_callback_add(E_File_Dialog *dia, void (*func)(E_File_Dialog *dia, char *file, void *data), void *data);
#endif
#endif
Evas_Coord x, y, w, h; /* coords */
void (*func) (Evas_Object *obj, char *file, void *data); /* selection cb */
+ void (*func_hilite) (Evas_Object *obj, char *file, void *data); /* selection cb */
void *func_data; /* selection cb data */
};
static void _e_smart_clip_unset(Evas_Object *obj);
static void _e_smart_init(void);
static void _e_file_selector_selected_cb(Evas_Object *obj, char *file, void *data);
+static void _e_file_selector_hilited_cb(Evas_Object *obj, char *file, void *data);
static void _e_file_selector_scroll_set(Evas_Object *obj, Evas_Coord x, Evas_Coord y);
static void _e_file_selector_scroll_get(Evas_Object *obj, Evas_Coord *x, Evas_Coord *y);
static void _e_file_selector_scroll_max_get(Evas_Object *obj, Evas_Coord *x, Evas_Coord *y);
}
void
-e_file_selector_callback_add(Evas_Object *obj, void (*func) (Evas_Object *obj, char *file, void *data), void *data)
+e_file_selector_callback_add(Evas_Object *obj, void (*func) (Evas_Object *obj, char *file, void *data), void (*func_hilite) (Evas_Object *obj, char *file, void *data), void *data)
{
API_ENTRY return;
sd->func = func;
+ sd->func_hilite = func_hilite;
sd->func_data = data;
}
sd->h = 0;
sd->parent = obj;
sd->func = NULL;
+ sd->func_hilite = NULL;
sd->func_data = NULL;
sd->view = E_FILE_SELECTOR_ICONVIEW;
e_fm_dir_set(sd->files, home);
E_FREE(home);
- e_fm_selector_enable(sd->files, _e_file_selector_selected_cb, sd);
+ e_fm_selector_enable(sd->files, _e_file_selector_selected_cb, _e_file_selector_hilited_cb, sd);
evas_object_smart_member_add(sd->files, obj);
e_scrollframe_extern_pan_set(sd->frame, sd->files,
sd->func(sd->parent, file, sd->func_data);
}
+_e_file_selector_hilited_cb(Evas_Object *obj, char *file, void *data)
+{
+ E_Smart_Data *sd;
+
+ sd = data;
+ if(sd->func_hilite)
+ sd->func_hilite(sd->parent, file, sd->func_data);
+}
+
/* never need to touch this */
static void
EAPI Evas_Object *e_file_selector_add(Evas *evas);
EAPI void e_file_selector_view_set(Evas_Object *object, int view);
EAPI int e_file_selector_view_get(Evas_Object *object);
-EAPI void e_file_selector_callback_add(Evas_Object *obj, void (*func) (Evas_Object *obj, char *file, void *data), void *data);
+EAPI void e_file_selector_callback_add(Evas_Object *obj, void (*func) (Evas_Object *obj, char *file, void *data), void (*hilite_func) (Evas_Object *obj, char *file, void *data), void *data);
#endif
#endif
{
fileman->selector.func = func;
fileman->selector.data = data;
- e_fm_selector_enable(fileman->smart, _e_fileman_selector_cb, fileman);
+ e_fm_selector_enable(fileman->smart, _e_fileman_selector_cb, NULL, fileman);
}
void
int is_selector;
void (*selector_func) (Evas_Object *object, char *file, void *data);
void *selector_data;
+ void (*selector_hilite_func) (Evas_Object *object, char *file, void *data);
Evas_Coord x, y, w, h;
static int _e_fm_files_sort_layout_name_cb (void *d1, void *d2);
static void _e_fm_selector_send_file (E_Fm_Icon *icon);
+static void _e_fm_selector_send_hilite_file (E_Fm_Icon *icon);
static char *_e_fm_dir_meta_dir_id(char *dir);
static int _e_fm_dir_meta_load(E_Fm_Smart_Data *sd);
}
void
-e_fm_selector_enable(Evas_Object *object, void (*func)(Evas_Object *object, char *file, void *data), void *data)
+e_fm_selector_enable(Evas_Object *object, void (*func)(Evas_Object *object, char *file, void *data), void (*hilite_func)(Evas_Object *object, char *file, void *data), void *data)
{
E_Fm_Smart_Data *sd;
sd->is_selector = 1;
sd->selector_func = func;
sd->selector_data = data;
+ sd->selector_hilite_func = hilite_func;
}
/* This isnt working yet */
}
else
{
+ if(icon->sd->is_selector && icon->file->type == E_FM_FILE_TYPE_FILE)
+ _e_fm_selector_send_hilite_file(icon);
+
if(icon->sd->win)
{
icon->sd->drag.start = 1;
icon->sd->selector_func(icon->sd->object, strdup(icon->file->path), icon->sd->selector_data);
}
+static void
+_e_fm_selector_send_hilite_file(E_Fm_Icon *icon)
+{
+ icon->sd->selector_hilite_func(icon->sd->object, strdup(icon->file->path), icon->sd->selector_data);
+}
+
static char *
_e_fm_dir_meta_dir_id(char *dir)
{
EAPI void e_fm_reconfigure_callback_add(Evas_Object *object, void (*func)(void *data, Evas_Object *obj, E_Event_Fm_Reconfigure *ev), void *data);
EAPI int e_fm_freeze(Evas_Object *freeze);
EAPI int e_fm_thaw(Evas_Object *freeze);
-EAPI void e_fm_selector_enable(Evas_Object *object, void (*func)(Evas_Object *object, char *file, void *data), void *data);
+EAPI void e_fm_selector_enable(Evas_Object *object, void (*func)(Evas_Object *object, char *file, void *data), void (*hilite_func)(Evas_Object *object, char *file, void *data), void *data);
EAPI void e_fm_background_set(Evas_Object *object, Evas_Object *bg);
EAPI Evas_Object *e_fm_icon_create(void *data);
void
_e_icon_canvas_tile_pack(E_Icon_Canvas_Tile *t, E_Icon_Canvas_Item *li)
{
+ if(!t)
+ return;
t->items = evas_list_append(t->items, li);
li->tile = t;
if(t->visible)
char **valptr;
void (*select_func) (Evas_Object *obj, char *file, void *data);
void *select_data;
+ void (*hilite_func) (Evas_Object *obj, char *file, void *data);
+ void *hilite_data;
};
static void _e_wid_del_hook(Evas_Object *obj);
static void _e_wid_focus_steal(void *data, Evas *e, Evas_Object *obj, void *event_info);
static void _e_wid_fileman_selected_cb(Evas_Object *obj, char *file, void *data);
+static void _e_wid_fileman_hilited_cb(Evas_Object *obj, char *file, void *data);
/* local subsystem functions */
/* this is crashing, see why */
#if 0
E_FREE(*(wd->valptr));
- *(wd->valptr) = strdup(file);
-#endif
+#endif
+ if(wd->valptr)
+ *(wd->valptr) = strdup(file);
+
if (wd->select_func)
wd->select_func(wd->wid, file, wd->select_data);
- printf("e_widget_fileman: %s\n", file);
+ printf("e_widget_fileman (selected) : %s\n", file);
+}
+
+static void
+_e_wid_fileman_hilited_cb(Evas_Object *obj, char *file, void *data)
+{
+ E_Widget_Data *wd;
+
+ wd = data;
+
+/* this is crashing, see why */
+#if 0
+ E_FREE(*(wd->valptr));
+#endif
+ if(wd->valptr)
+ *(wd->valptr) = strdup(file);
+
+
+ if (wd->hilite_func)
+ wd->hilite_func(wd->wid, file, wd->select_data);
+
+ printf("e_widget_fileman (hilited): %s\n", file);
}
/* externally accessible functions */
e_widget_data_set(obj, wd);
wd->o_fm = e_file_selector_add(evas);
- e_file_selector_callback_add(wd->o_fm, _e_wid_fileman_selected_cb, wd);
+ e_file_selector_callback_add(wd->o_fm, _e_wid_fileman_selected_cb, _e_wid_fileman_hilited_cb, wd);
evas_object_show(wd->o_fm);
evas_object_resize(wd->o_fm, 300, 200);
e_widget_min_size_set(obj, 300, 200);
wd->select_func = func;
wd->select_data = data;
}
+
+void
+e_widget_fileman_hilite_callback_add(Evas_Object *obj, void (*func) (Evas_Object *obj, char *file, void *data), void *data)
+{
+ E_Widget_Data *wd;
+
+ wd = e_widget_data_get(obj);
+ wd->hilite_func = func;
+ wd->hilite_data = data;
+}
void (*select_func) (Evas_Object *obj, char *file, void *data);
void *select_data;
+ void (*hilite_func) (Evas_Object *obj, char *file, void *data);
+ void *hilite_data;
};
static void _e_wid_del_hook(Evas_Object *obj);
static void _e_wid_signal_cb1(void *data, Evas_Object *obj, const char *emission, const char *source);
static void _e_wid_focus_steal(void *data, Evas *e, Evas_Object *obj, void *event_info);
static void _e_wid_select_cb(E_File_Dialog *dia, char *file, void *data);
+static void _e_wid_hilite_cb(E_File_Dialog *dia, char *file, void *data);
/* local subsystem functions */
wd->valptr = file;
wd->select_func = NULL;
wd->select_data = NULL;
+ wd->hilite_func = NULL;
+ wd->hilite_data = NULL;
wd->obj = obj;
e_widget_data_set(obj, wd);
wd = calloc(1, sizeof(E_Widget_Data));
wd->valptr = file;
wd->select_func = NULL;
- wd->select_data = NULL;
+ wd->select_data = NULL;
+ wd->hilite_func = NULL;
+ wd->hilite_data = NULL;
wd->obj = obj;
e_widget_data_set(obj, wd);
wd->select_data = data;
}
+void
+e_widget_iconsel_hilite_callback_add(Evas_Object *obj, void (*func)(Evas_Object *obj, char *file, void *data), void *data)
+{
+ E_Widget_Data *wd;
+
+ wd = e_widget_data_get(obj);
+ wd->hilite_func = func;
+ wd->hilite_data = data;
+}
+
static void
_e_wid_del_hook(Evas_Object *obj)
{
if (!dia) return;
e_file_dialog_title_set(dia, "Select File");
e_file_dialog_select_callback_add(dia, _e_wid_select_cb, wd);
+ e_file_dialog_hilite_callback_add(dia, _e_wid_hilite_cb, wd);
e_file_dialog_show(dia);
}
*(wd->valptr) = strdup(file);
e_object_del(E_OBJECT(dia));
}
+
+static void
+_e_wid_hilite_cb(E_File_Dialog *dia, char *file, void *data)
+{
+ E_Widget_Data *wd;
+ char *ext;
+
+ wd = data;
+
+ ext = strrchr(file, '.');
+ if (!ext) return;
+ if ((strcasecmp(ext, ".png")) &&
+ (strcasecmp(ext, ".jpg")) &&
+ (strcasecmp(ext, ".jpeg")))
+ return;
+
+ if (wd->hilite_func)
+ wd->hilite_func(wd->obj, file, wd->select_data);
+
+ //e_icon_file_set(wd->o_icon, file);
+ E_FREE(*(wd->valptr));
+ *(wd->valptr) = strdup(file);
+}
EAPI Evas_Object *e_widget_iconsel_add(Evas *evas, Evas_Object *icon, Evas_Coord minw, Evas_Coord minh, char **file);
EAPI Evas_Object *e_widget_iconsel_add_from_file(Evas *evas, char *icon, Evas_Coord minw, Evas_Coord minh, char **file);
EAPI void e_widget_iconsel_select_callback_add(Evas_Object *obj, void (*func)(Evas_Object *obj, char *file, void *data), void *data);
+EAPI void e_widget_iconsel_hilite_callback_add(Evas_Object *obj, void (*func)(Evas_Object *obj, char *file, void *data), void *data);
#endif
#endif