e_entry -> elm_entry conversion
[platform/upstream/enlightenment.git] / src / bin / e_entry_dialog.c
index 8229b48..fad92c1 100644 (file)
 #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);
 }
+