Xkbswitch: Use E_Dialog (which uses elm) instead of elm_win directly to make use of built in extra features.

This commit is contained in:
Stephen 'Okra' Houston 2017-04-17 14:07:23 -05:00
parent 86532962b5
commit 43ebf4a011
1 changed files with 33 additions and 45 deletions

View File

@ -60,7 +60,7 @@ struct _E_Config_Dialog_Data
int only_label; int only_label;
int dont_touch_my_damn_keyboard; int dont_touch_my_damn_keyboard;
Evas_Object *dlg_add_new; E_Dialog *dlg_add_new;
E_Config_Dialog *cfd; E_Config_Dialog *cfd;
}; };
@ -105,11 +105,11 @@ static void _cb_misc_up(void *data, Evas_Object *obj, void *event);
static void _popup_cancel_clicked(void *data, Evas_Object *obj, void *event_info); static void _popup_cancel_clicked(void *data, Evas_Object *obj, void *event_info);
static void _dlg_add_cb_ok(void *data, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED); static void _dlg_add_cb_ok(void *data, E_Dialog *dlg);
static void _dlg_add_cb_cancel(void *data, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED); static void _dlg_add_cb_cancel(void *data EINA_UNUSED, E_Dialog *dlg);
static Evas_Object *_dlg_add_new(E_Config_Dialog_Data *cfdata); static E_Dialog *_dlg_add_new(E_Config_Dialog_Data *cfdata);
static void _dlg_add_cb_del(void *data, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED); static void _dlg_add_cb_del(void *object);
static Eina_Bool _cb_dlg_fill_delay(void *data); static Eina_Bool _cb_dlg_fill_delay(void *data);
@ -888,7 +888,7 @@ _cb_add(void *data, Evas_Object *obj EINA_UNUSED, void *event EINA_UNUSED)
E_Config_Dialog_Data *cfdata; E_Config_Dialog_Data *cfdata;
if (!(cfdata = data)) return; if (!(cfdata = data)) return;
if (cfdata->dlg_add_new) elm_win_raise(cfdata->dlg_add_new); if (cfdata->dlg_add_new) elm_win_raise(cfdata->dlg_add_new->win);
else cfdata->dlg_add_new = _dlg_add_new(cfdata); else cfdata->dlg_add_new = _dlg_add_new(cfdata);
} }
@ -1348,24 +1348,26 @@ _show_variant(void *data, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UN
evas_object_show(cfdata->variant_list); evas_object_show(cfdata->variant_list);
} }
static Evas_Object * static E_Dialog *
_dlg_add_new(E_Config_Dialog_Data *cfdata) _dlg_add_new(E_Config_Dialog_Data *cfdata)
{ {
Evas_Object *dlg, *but, *tb; E_Dialog *dlg;
Evas_Object *mainn, *list, *layout, *modelss, *variants, *box; Evas_Object *mainn, *list, *layout, *modelss, *variants, *tb, *box;
E_Zone *zone = e_zone_current_get(); E_Zone *zone = e_zone_current_get();
Elm_Object_Item *it; Elm_Object_Item *it;
if (!(dlg = elm_win_util_dialog_add(e_comp->elm, "xkbswitch_config_add_dialog", _("Add New Configuration")))) return NULL; if (!(dlg = e_dialog_new(e_win_evas_win_get(cfdata->evas), "E", "xkbswitch_config_add_dialog"))) return NULL;
elm_win_icon_name_set(dlg, "preferences-desktop-keyboard"); e_dialog_resizable_set(dlg, 1);
evas_object_event_callback_add(dlg, EVAS_CALLBACK_FREE, _dlg_add_cb_del, cfdata); dlg->data = cfdata;
elm_win_autodel_set(dlg, EINA_TRUE); e_dialog_title_set(dlg, _("Add New Configuration"));
elm_win_center(dlg, 1, 1); e_dialog_border_icon_set(dlg, "preferences-desktop-keyboard");
e_object_del_attach_func_set(E_OBJECT(dlg), _dlg_add_cb_del);
elm_win_center(dlg->win, 1, 1);
mainn = elm_box_add(dlg); mainn = elm_box_add(dlg->win);
elm_box_horizontal_set(mainn, EINA_FALSE); elm_box_horizontal_set(mainn, EINA_FALSE);
E_EXPAND(mainn); E_EXPAND(mainn);
elm_win_resize_object_add(dlg, mainn); e_dialog_content_set(dlg, mainn, 0, 0);
evas_object_show(mainn); evas_object_show(mainn);
box = elm_box_add(mainn); box = elm_box_add(mainn);
@ -1422,29 +1424,16 @@ _dlg_add_new(E_Config_Dialog_Data *cfdata)
evas_object_show(variants); evas_object_show(variants);
cfdata->variant_list = variants; cfdata->variant_list = variants;
box = elm_box_add(mainn); e_dialog_button_add(dlg, _("OK"), NULL, _dlg_add_cb_ok, cfdata);
elm_box_horizontal_set(box, EINA_TRUE); e_dialog_button_add(dlg, _("Cancel"), NULL, _dlg_add_cb_cancel, cfdata);
E_WEIGHT(box, 0.0, 0.0);
E_ALIGN(box, 0.5, 0.5);
elm_box_pack_end(mainn, box);
evas_object_show(box);
but = elm_button_add(box); e_dialog_button_disable_num_set(dlg, 0, 1);
elm_object_text_set(but, _("OK")); e_dialog_button_disable_num_set(dlg, 1, 0);
evas_object_smart_callback_add(but, "clicked", _dlg_add_cb_ok, cfdata);
elm_box_pack_end(box, but);
evas_object_show(but);
but = elm_button_add(box); cfdata->dlg_evas = evas_object_evas_get(dlg->win);
elm_object_text_set(but, _("Cancel")); evas_object_resize(dlg->win, zone->w / 3, zone->h / 3);
evas_object_smart_callback_add(but, "clicked", _dlg_add_cb_cancel, cfdata);
elm_box_pack_end(box, but);
evas_object_show(but);
cfdata->dlg_evas = evas_object_evas_get(dlg);
evas_object_resize(dlg, zone->w / 3, zone->h / 3);
evas_object_resize(mainn, zone->w / 3, zone->h / 3); evas_object_resize(mainn, zone->w / 3, zone->h / 3);
evas_object_show(dlg); e_dialog_show(dlg);
if (cfdata->dlg_fill_delay) ecore_timer_del(cfdata->dlg_fill_delay); if (cfdata->dlg_fill_delay) ecore_timer_del(cfdata->dlg_fill_delay);
cfdata->dlg_fill_delay = ecore_timer_loop_add(0.2, _cb_dlg_fill_delay, cfdata); cfdata->dlg_fill_delay = ecore_timer_loop_add(0.2, _cb_dlg_fill_delay, cfdata);
@ -1455,7 +1444,7 @@ _dlg_add_new(E_Config_Dialog_Data *cfdata)
} }
static void static void
_dlg_add_cb_ok(void *data, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED) _dlg_add_cb_ok(void *data, E_Dialog *dlg)
{ {
E_Config_Dialog_Data *cfdata = data; E_Config_Dialog_Data *cfdata = data;
E_XKB_Layout *l; E_XKB_Layout *l;
@ -1496,17 +1485,14 @@ _dlg_add_cb_ok(void *data, Evas_Object *obj EINA_UNUSED, void *event_info EINA_U
elm_list_item_append(cfdata->used_list, buf, ic, NULL, NULL, cl); elm_list_item_append(cfdata->used_list, buf, ic, NULL, NULL, cl);
elm_list_go(cfdata->used_list); elm_list_go(cfdata->used_list);
evas_object_del(cfdata->dlg_add_new); e_object_del(E_OBJECT(dlg));
cfdata->dlg_add_new = NULL;
e_config_dialog_changed_set(cfdata->cfd, _check_changed(cfdata)); e_config_dialog_changed_set(cfdata->cfd, _check_changed(cfdata));
} }
static void static void
_dlg_add_cb_cancel(void *data, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED) _dlg_add_cb_cancel(void *data EINA_UNUSED, E_Dialog *dlg)
{ {
E_Config_Dialog_Data *cfdata = data; e_object_del(E_OBJECT(dlg));
evas_object_del(cfdata->dlg_add_new);
cfdata->dlg_add_new = NULL;
} }
static char * static char *
@ -1664,6 +1650,7 @@ _cb_layout_select(void *data, Evas_Object *obj EINA_UNUSED, void *event_info EIN
elm_genlist_item_class_free(itc); elm_genlist_item_class_free(itc);
elm_genlist_item_selected_set(elm_genlist_first_item_get(cfdata->model_list), EINA_TRUE); elm_genlist_item_selected_set(elm_genlist_first_item_get(cfdata->model_list), EINA_TRUE);
elm_genlist_item_selected_set(elm_genlist_first_item_get(cfdata->variant_list), EINA_TRUE); elm_genlist_item_selected_set(elm_genlist_first_item_get(cfdata->variant_list), EINA_TRUE);
e_dialog_button_disable_num_set(cfdata->dlg_add_new, 0, 0);
} }
static Eina_Bool static Eina_Bool
@ -1680,9 +1667,10 @@ _cb_fill_delay(void *data)
} }
static void static void
_dlg_add_cb_del(void *data, Evas *e EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED) _dlg_add_cb_del(void *object)
{ {
E_Config_Dialog_Data *cfdata = data; E_Dialog *dlg = object;
E_Config_Dialog_Data *cfdata = dlg->data;
cfdata->dlg_add_new = NULL; cfdata->dlg_add_new = NULL;
} }