#include "e.h"
-typedef struct _E_Entry_Dialog E_Entry_Dialog;
-struct _E_Entry_Dialog
-{
- struct
- {
- void *data;
- void (*func)(char *text, void *data);
- } ok;
- struct
- {
- void *data;
- void (*func)(void *data);
- } cancel;
- E_Dialog *dia;
- Evas_Object *entry;
- char *text;
-};
-
/* Private function definitions */
-static void _e_entry_dialog_delete(E_Win *win);
+static void _e_entry_dia_del(void *data);
+static void _e_entry_dialog_free(E_Entry_Dialog *dia);
static void _e_entry_dialog_ok(void *data, E_Dialog *dia);
static void _e_entry_dialog_cancel(void *data, E_Dialog *dia);
+static void _e_entry_dialog_delete(E_Dialog *dia, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED);
+static void _e_entry_cb_key_down(void *data, Evas_Object *obj, void *event_info);
/* Externally accesible functions */
-EAPI void
-e_entry_dialog_show(const char *title, const char *icon, const char *text,
- const char *button_text, const char *button2_text,
- void (*func)(char *text, void *data),
- void (*func2)(void *data), void *data)
+EAPI E_Entry_Dialog *
+e_entry_dialog_show(const char *title, const char *icon, const char *text,
+ const char *initial_text,
+ const char *button_text, const char *button2_text,
+ void (*ok_func)(void *data, char *text),
+ void (*cancel_func)(void *data), void *data)
{
E_Entry_Dialog *ed;
E_Dialog *dia;
Evas_Object *o, *ob;
+ Evas_Modifier_Mask mask;
int w, h;
-
- ed = E_NEW(E_Entry_Dialog, 1);
- ed->ok.func = func;
+ Evas *e;
+
+ ed = E_OBJECT_ALLOC(E_Entry_Dialog, E_ENTRY_DIALOG_TYPE, _e_entry_dialog_free);
+ ed->ok.func = ok_func;
ed->ok.data = data;
- ed->cancel.func = func2;
+ ed->cancel.func = cancel_func;
ed->cancel.data = data;
-
- dia = e_dialog_new(e_container_current_get(e_manager_current_get()));
- if (!dia)
+ if (initial_text)
+ ed->text = strdup(initial_text);
+
+ dia = e_dialog_new(NULL, "E", "_entry_dialog");
+ if (!dia)
{
- E_FREE(ed);
- return;
+ e_object_del(E_OBJECT(ed));
+ return NULL;
}
dia->data = ed;
ed->dia = dia;
-
- e_win_delete_callback_set(dia->win, _e_entry_dialog_delete);
-
+
+ mask = 0;
+ evas_object_key_ungrab(dia->event_object, "space", mask, ~mask);
+ e_object_del_attach_func_set(E_OBJECT(dia), _e_entry_dia_del);
+ evas_object_event_callback_add(dia->win, EVAS_CALLBACK_DEL, (Evas_Object_Event_Cb)_e_entry_dialog_delete, dia);
+
if (title) e_dialog_title_set(dia, title);
if (icon) e_dialog_icon_set(dia, icon, 64);
-
- o = e_widget_list_add(dia->win->evas, 0, 0);
- if (text)
+
+ e = evas_object_evas_get(dia->win);
+ o = e_widget_list_add(e, 0, 0);
+ if (text)
{
- ob = e_widget_label_add(dia->win->evas, text);
- e_widget_list_object_append(o, ob, 1, 0, 0.5);
+ ob = e_widget_label_add(e, text);
+ e_widget_list_object_append(o, ob, 1, 0, 0.5);
}
-
- ed->entry = e_widget_entry_add(dia->win->evas, &(ed->text));
+
+ ed->entry = e_widget_entry_add(dia->win, &(ed->text), NULL, NULL, NULL);
+ evas_object_smart_callback_add(ed->entry, "key_down", _e_entry_cb_key_down, ed);
e_widget_list_object_append(o, ed->entry, 1, 1, 0.5);
- e_widget_min_size_get(o, &w, &h);
- e_dialog_content_set(dia, o, w, h);
-
- e_dialog_button_add(dia, !button_text ? _("Ok") : button_text, NULL, _e_entry_dialog_ok, ed);
+ e_widget_size_min_get(o, &w, &h);
+ e_dialog_content_set(dia, o, 2 * w, h);
+
+ e_dialog_button_add(dia, !button_text ? _("OK") : button_text, NULL, _e_entry_dialog_ok, ed);
e_dialog_button_add(dia, !button2_text ? _("Cancel") : button2_text, NULL, _e_entry_dialog_cancel, ed);
-
- e_win_centered_set(dia->win, 1);
+
+ elm_win_center(dia->win, 1, 1);
e_dialog_show(dia);
+ e_widget_focus_set(ed->entry, 1);
+ e_widget_entry_select_all(ed->entry);
+ return ed;
}
/* Private Function Bodies */
static void
-_e_entry_dialog_ok(void *data, E_Dialog *dia)
+_e_entry_dia_del(void *data)
+{
+ E_Dialog *dia = data;
+
+ evas_object_event_callback_add(dia->win, EVAS_CALLBACK_DEL, (Evas_Object_Event_Cb)_e_entry_dialog_delete, dia);
+ e_object_del(dia->data);
+}
+
+static void
+_e_entry_dialog_free(E_Entry_Dialog *ed)
+{
+ e_object_del(E_OBJECT(ed->dia));
+ E_FREE(ed->text);
+ free(ed);
+}
+
+static void
+_e_entry_dialog_ok(void *data, E_Dialog *dia __UNUSED__)
{
E_Entry_Dialog *ed;
-
+
ed = data;
- if (ed->ok.func) ed->ok.func(ed->text, ed->ok.data);
- _e_entry_dialog_delete(ed->dia->win);
+ e_object_ref(E_OBJECT(ed));
+ if (ed->ok.func) ed->ok.func(ed->ok.data, ed->text);
+ e_object_del(E_OBJECT(ed));
+ e_object_unref(E_OBJECT(ed));
}
static void
-_e_entry_dialog_cancel(void *data, E_Dialog *dia)
+_e_entry_dialog_cancel(void *data, E_Dialog *dia __UNUSED__)
{
E_Entry_Dialog *ed;
-
+
ed = data;
+ e_object_ref(E_OBJECT(ed));
if (ed->cancel.func) ed->cancel.func(ed->cancel.data);
- _e_entry_dialog_delete(ed->dia->win);
+ e_object_del(E_OBJECT(ed));
+ e_object_unref(E_OBJECT(ed));
}
static void
-_e_entry_dialog_delete(E_Win *win)
+_e_entry_dialog_delete(E_Dialog *dia, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
{
- E_Dialog *dia;
+ e_object_del(E_OBJECT(dia->data));
+}
+
+static void
+_e_entry_cb_key_down(void *data, Evas_Object *obj __UNUSED__, void *event_info)
+{
+ Evas_Event_Key_Down *ev;
E_Entry_Dialog *ed;
-
- dia = win->data;
- ed = dia->data;
-
- e_object_del(E_OBJECT(dia));
- free(ed);
+
+ ev = event_info;
+ if (!(ed = data)) return;
+ if (!strcmp(ev->key, "Return"))
+ _e_entry_dialog_ok(data, ed->dia);
+ else
+ if (!strcmp(ev->key, "Escape"))
+ _e_entry_dialog_cancel(data, ed->dia);
}
+