change pager advanced settings grab dialog to use e_grab_dialog

SVN revision: 75663
This commit is contained in:
Mike Blumenkrantz 2012-08-24 13:55:26 +00:00
parent de494950d0
commit 2f2764c63a
1 changed files with 42 additions and 82 deletions

View File

@ -20,7 +20,7 @@ struct _E_Config_Dialog_Data
struct
{
Ecore_X_Window bind_win;
E_Dialog *dia;
E_Grab_Dialog *dia;
Eina_List *hdls;
int btn;
} grab;
@ -30,6 +30,7 @@ struct _E_Config_Dialog_Data
Eina_List *popup_list, *urgent_list;
} gui;
int drag_resist, flip_desk, show_desk_names, live_preview;
E_Config_Dialog *cfd;
};
/* local function prototypes */
@ -46,7 +47,6 @@ static void _update_btn_lbl(E_Config_Dialog_Data *cfdata);
static void _grab_window_show(void *data1, void *data2);
static Eina_Bool _grab_cb_mouse_down(void *data, int type, void *event);
static Eina_Bool _grab_cb_key_down(void *data, int type, void *event);
static void _grab_window_hide(E_Config_Dialog_Data *cfdata);
static void _cb_disable_check_list(void *data, Evas_Object *obj);
void
@ -118,10 +118,11 @@ _free_data(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfdata)
}
static Evas_Object *
_basic_create(E_Config_Dialog *cfd __UNUSED__, Evas *evas, E_Config_Dialog_Data *cfdata)
_basic_create(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
{
Evas_Object *ol, *of, *ow;
cfdata->cfd = cfd;
ol = e_widget_list_add(evas, 0, 0);
of = e_widget_framelist_add(evas, _("General"), 0);
@ -174,11 +175,12 @@ _basic_check_changed(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfda
}
static Evas_Object *
_adv_create(E_Config_Dialog *cfd __UNUSED__, Evas *evas, E_Config_Dialog_Data *cfdata)
_adv_create(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
{
Evas_Object *otb, *ol, *ow;
Evas_Object *pc, *uc;
cfdata->cfd = cfd;
otb = e_widget_toolbook_add(evas, (48 * e_scale), (48 * e_scale));
/* General Page */
@ -362,15 +364,23 @@ _update_btn_lbl(E_Config_Dialog_Data *cfdata)
e_widget_button_label_set(cfdata->gui.ob3, lbl);
}
static void
_grab_window_del(void *data)
{
E_Config_Dialog_Data *cfdata;
cfdata = e_object_data_get(data);
if (!cfdata) return;
cfdata->grab.dia = NULL;
_update_btn_lbl(cfdata);
}
static void
_grab_window_show(void *data1, void *data2)
{
E_Manager *man = NULL;
E_Config_Dialog_Data *cfdata = NULL;
Ecore_Event_Handler *hdl = NULL;
E_Config_Dialog_Data *cfdata;
if (!(cfdata = data2)) return;
man = e_manager_current_get();
cfdata->grab.btn = 0;
if ((long)data1 == BUTTON_DRAG)
@ -378,64 +388,19 @@ _grab_window_show(void *data1, void *data2)
else if ((long)data1 == BUTTON_NOPLACE)
cfdata->grab.btn = 2;
cfdata->grab.dia = e_dialog_new(e_container_current_get(man), "Pager",
"_pager_button_grab_dialog");
if (!cfdata->grab.dia) return;
e_dialog_title_set(cfdata->grab.dia, _("Pager Button Grab"));
e_dialog_icon_set(cfdata->grab.dia, "preferences-desktop-mouse", 48);
e_dialog_text_set(cfdata->grab.dia, _("Please press a mouse button<br>"
"Press <hilight>Escape</hilight> to abort.<br>"
"Or <hilight>Del</hilight> to reset the button."));
e_win_centered_set(cfdata->grab.dia->win, 1);
e_win_borderless_set(cfdata->grab.dia->win, 1);
cfdata->grab.bind_win = ecore_x_window_input_new(man->root, 0, 0,
man->w, man->h);
ecore_x_window_show(cfdata->grab.bind_win);
if (!e_grabinput_get(cfdata->grab.bind_win, 0, cfdata->grab.bind_win))
{
ecore_x_window_free(cfdata->grab.bind_win);
cfdata->grab.bind_win = 0;
e_object_del(E_OBJECT(cfdata->grab.dia));
cfdata->grab.dia = NULL;
return;
}
hdl = ecore_event_handler_add(ECORE_EVENT_KEY_DOWN,
_grab_cb_key_down, cfdata);
cfdata->grab.hdls = eina_list_append(cfdata->grab.hdls, hdl);
hdl = ecore_event_handler_add(ECORE_EVENT_MOUSE_BUTTON_DOWN,
_grab_cb_mouse_down, cfdata);
cfdata->grab.hdls = eina_list_append(cfdata->grab.hdls, hdl);
e_dialog_show(cfdata->grab.dia);
ecore_x_icccm_transient_for_set(cfdata->grab.dia->win->evas_win,
pager_config->config_dialog->dia->win->evas_win);
cfdata->grab.dia = e_grab_dialog_show(cfdata->cfd->dia->win, EINA_TRUE, _grab_cb_key_down, _grab_cb_mouse_down, NULL, cfdata);
e_object_data_set(E_OBJECT(cfdata->grab.dia), cfdata);
e_object_del_attach_func_set(E_OBJECT(cfdata->grab.dia), _grab_window_del);
}
static Eina_Bool
_grab_cb_mouse_down(__UNUSED__ void *data, __UNUSED__ int type, void *event)
_grab_cb_mouse_down(void *data, __UNUSED__ int type, void *event)
{
E_Config_Dialog_Data *cfdata = NULL;
Ecore_Event_Mouse_Button *ev;
ev = event;
if (!(cfdata = data)) return ECORE_CALLBACK_PASS_ON;
if (ev->window != cfdata->grab.bind_win) return ECORE_CALLBACK_PASS_ON;
if (ev->buttons == cfdata->btn.drag)
cfdata->btn.drag = 0;
else if (ev->buttons == cfdata->btn.noplace)
cfdata->btn.noplace = 0;
else if (ev->buttons == cfdata->btn.desk)
cfdata->btn.desk = 0;
if (cfdata->grab.btn == 1)
cfdata->btn.drag = ev->buttons;
else if (cfdata->grab.btn == 2)
cfdata->btn.noplace = ev->buttons;
else
cfdata->btn.desk = ev->buttons;
if (ev->buttons == 3)
{
e_util_dialog_show(_("Attention"),
@ -444,20 +409,35 @@ _grab_cb_mouse_down(__UNUSED__ void *data, __UNUSED__ int type, void *event)
"code for context menus.<br>"
"This button only works in the popup."));
}
_grab_window_hide(cfdata);
else
{
if (ev->buttons == cfdata->btn.drag)
cfdata->btn.drag = 0;
else if (ev->buttons == cfdata->btn.noplace)
cfdata->btn.noplace = 0;
else if (ev->buttons == cfdata->btn.desk)
cfdata->btn.desk = 0;
if (cfdata->grab.btn == 1)
cfdata->btn.drag = ev->buttons;
else if (cfdata->grab.btn == 2)
cfdata->btn.noplace = ev->buttons;
else
cfdata->btn.desk = ev->buttons;
}
e_object_del(E_OBJECT(cfdata->grab.dia));
return ECORE_CALLBACK_PASS_ON;
}
static Eina_Bool
_grab_cb_key_down(__UNUSED__ void *data, __UNUSED__ int type, void *event)
_grab_cb_key_down(void *data, __UNUSED__ int type, void *event)
{
E_Config_Dialog_Data *cfdata = NULL;
Ecore_Event_Key *ev;
ev = event;
if (!(cfdata = data)) return ECORE_CALLBACK_PASS_ON;
if (ev->window != cfdata->grab.bind_win) return ECORE_CALLBACK_PASS_ON;
if (!strcmp(ev->keyname, "Escape")) _grab_window_hide(cfdata);
if (!strcmp(ev->keyname, "Delete"))
{
if (cfdata->grab.btn == 1)
@ -466,31 +446,11 @@ _grab_cb_key_down(__UNUSED__ void *data, __UNUSED__ int type, void *event)
cfdata->btn.noplace = 0;
else
cfdata->btn.desk = 0;
_grab_window_hide(cfdata);
}
e_object_del(E_OBJECT(cfdata->grab.dia));
return ECORE_CALLBACK_PASS_ON;
}
static void
_grab_window_hide(E_Config_Dialog_Data *cfdata)
{
while (cfdata->grab.hdls)
{
ecore_event_handler_del(cfdata->grab.hdls->data);
cfdata->grab.hdls =
eina_list_remove_list(cfdata->grab.hdls, cfdata->grab.hdls);
}
cfdata->grab.hdls = NULL;
e_grabinput_release(cfdata->grab.bind_win, cfdata->grab.bind_win);
if (cfdata->grab.bind_win) ecore_x_window_free(cfdata->grab.bind_win);
cfdata->grab.bind_win = 0;
if (cfdata->grab.dia) e_object_del(E_OBJECT(cfdata->grab.dia));
cfdata->grab.dia = NULL;
_update_btn_lbl(cfdata);
}
static void
_cb_disable_check_list(void *data, Evas_Object *obj)
{