realised we need to approve if the dialog will close on an ok - as there may
be an error and we need to complain to the user. add some comments too. SVN revision: 17533
This commit is contained in:
parent
d41a915bf9
commit
510d2b7719
|
@ -130,13 +130,14 @@ static void
|
||||||
_e_config_dialog_cb_ok(void *data, E_Dialog *dia)
|
_e_config_dialog_cb_ok(void *data, E_Dialog *dia)
|
||||||
{
|
{
|
||||||
E_Config_Dialog *cfd;
|
E_Config_Dialog *cfd;
|
||||||
|
int ok = 0;
|
||||||
|
|
||||||
cfd = dia->data;
|
cfd = dia->data;
|
||||||
if (cfd->view_type == E_CONFIG_DIALOG_CFDATA_TYPE_BASIC)
|
if (cfd->view_type == E_CONFIG_DIALOG_CFDATA_TYPE_BASIC)
|
||||||
cfd->view.basic.apply_cfdata(cfd, cfd->cfdata);
|
ok = cfd->view.basic.apply_cfdata(cfd, cfd->cfdata);
|
||||||
else
|
else
|
||||||
cfd->view.advanced.apply_cfdata(cfd, cfd->cfdata);
|
ok = cfd->view.advanced.apply_cfdata(cfd, cfd->cfdata);
|
||||||
e_object_del(E_OBJECT(cfd));
|
if (ok) e_object_del(E_OBJECT(cfd));
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
|
@ -23,7 +23,7 @@ struct _E_Config_Dialog_View
|
||||||
void *(*create_cfdata) (E_Config_Dialog *cfd);
|
void *(*create_cfdata) (E_Config_Dialog *cfd);
|
||||||
void (*free_cfdata) (E_Config_Dialog *cfd, void *cfdata);
|
void (*free_cfdata) (E_Config_Dialog *cfd, void *cfdata);
|
||||||
struct {
|
struct {
|
||||||
void (*apply_cfdata) (E_Config_Dialog *cfd, void *cfdata);
|
int (*apply_cfdata) (E_Config_Dialog *cfd, void *cfdata);
|
||||||
Evas_Object *(*create_widgets) (E_Config_Dialog *cfd, Evas *evas, void *cfdata);
|
Evas_Object *(*create_widgets) (E_Config_Dialog *cfd, Evas *evas, void *cfdata);
|
||||||
} basic, advanced;
|
} basic, advanced;
|
||||||
};
|
};
|
||||||
|
|
|
@ -3,16 +3,17 @@
|
||||||
*/
|
*/
|
||||||
#include "e.h"
|
#include "e.h"
|
||||||
|
|
||||||
/* PROTOTYPES */
|
/* PROTOTYPES - same all the time */
|
||||||
typedef struct _CFData CFData;
|
typedef struct _CFData CFData;
|
||||||
|
|
||||||
static void *_create_data(E_Config_Dialog *cfd);
|
static void *_create_data(E_Config_Dialog *cfd);
|
||||||
static void _free_data(E_Config_Dialog *cfd, CFData *cfdata);
|
static void _free_data(E_Config_Dialog *cfd, CFData *cfdata);
|
||||||
static void _basic_apply_data(E_Config_Dialog *cfd, CFData *cfdata);
|
static int _basic_apply_data(E_Config_Dialog *cfd, CFData *cfdata);
|
||||||
static void _advanced_apply_data(E_Config_Dialog *cfd, CFData *cfdata);
|
static int _advanced_apply_data(E_Config_Dialog *cfd, CFData *cfdata);
|
||||||
static Evas_Object *_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata);
|
static Evas_Object *_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata);
|
||||||
static Evas_Object *_advanced_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata);
|
static Evas_Object *_advanced_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata);
|
||||||
|
|
||||||
|
/* Actual config data we will be playing with whil the dialog is active */
|
||||||
struct _CFData
|
struct _CFData
|
||||||
{
|
{
|
||||||
/*- BASIC -*/
|
/*- BASIC -*/
|
||||||
|
@ -25,7 +26,9 @@ struct _CFData
|
||||||
int always_click_to_focus;
|
int always_click_to_focus;
|
||||||
};
|
};
|
||||||
|
|
||||||
void e_int_config_focus(E_Container *con)
|
/* a nice easy setup function that does the dirty work */
|
||||||
|
void
|
||||||
|
e_int_config_focus(E_Container *con)
|
||||||
{
|
{
|
||||||
E_Config_Dialog *cfd;
|
E_Config_Dialog *cfd;
|
||||||
E_Config_Dialog_View v;
|
E_Config_Dialog_View v;
|
||||||
|
@ -45,6 +48,10 @@ void e_int_config_focus(E_Container *con)
|
||||||
static void *
|
static void *
|
||||||
_create_data(E_Config_Dialog *cfd)
|
_create_data(E_Config_Dialog *cfd)
|
||||||
{
|
{
|
||||||
|
/* Create cfdata - cfdata is a temporary block of config data that this
|
||||||
|
* dialog will be dealing with while configuring. it will be applied to
|
||||||
|
* the running systems/config in the apply methods
|
||||||
|
*/
|
||||||
CFData *cfdata;
|
CFData *cfdata;
|
||||||
|
|
||||||
cfdata = E_NEW(CFData, 1);
|
cfdata = E_NEW(CFData, 1);
|
||||||
|
@ -62,13 +69,15 @@ _create_data(E_Config_Dialog *cfd)
|
||||||
static void
|
static void
|
||||||
_free_data(E_Config_Dialog *cfd, CFData *cfdata)
|
_free_data(E_Config_Dialog *cfd, CFData *cfdata)
|
||||||
{
|
{
|
||||||
|
/* Free the cfdata */
|
||||||
free(cfdata);
|
free(cfdata);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**--APPLY--**/
|
/**--APPLY--**/
|
||||||
static void
|
static int
|
||||||
_basic_apply_data(E_Config_Dialog *cfd, CFData *cfdata)
|
_basic_apply_data(E_Config_Dialog *cfd, CFData *cfdata)
|
||||||
{
|
{
|
||||||
|
/* Actually take our cfdata settings and apply them in real life */
|
||||||
e_border_button_bindings_ungrab_all();
|
e_border_button_bindings_ungrab_all();
|
||||||
if (cfdata->mode == E_FOCUS_CLICK)
|
if (cfdata->mode == E_FOCUS_CLICK)
|
||||||
{
|
{
|
||||||
|
@ -96,11 +105,13 @@ _basic_apply_data(E_Config_Dialog *cfd, CFData *cfdata)
|
||||||
}
|
}
|
||||||
e_border_button_bindings_grab_all();
|
e_border_button_bindings_grab_all();
|
||||||
e_config_save_queue();
|
e_config_save_queue();
|
||||||
|
return 1; /* Apply was OK */
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static int
|
||||||
_advanced_apply_data(E_Config_Dialog *cfd, CFData *cfdata)
|
_advanced_apply_data(E_Config_Dialog *cfd, CFData *cfdata)
|
||||||
{
|
{
|
||||||
|
/* Actually take our cfdata settings and apply them in real life */
|
||||||
e_border_button_bindings_ungrab_all();
|
e_border_button_bindings_ungrab_all();
|
||||||
e_config->focus_policy = cfdata->focus_policy;
|
e_config->focus_policy = cfdata->focus_policy;
|
||||||
e_config->focus_setting = cfdata->focus_setting;
|
e_config->focus_setting = cfdata->focus_setting;
|
||||||
|
@ -109,14 +120,17 @@ _advanced_apply_data(E_Config_Dialog *cfd, CFData *cfdata)
|
||||||
e_config->always_click_to_focus = cfdata->always_click_to_focus;
|
e_config->always_click_to_focus = cfdata->always_click_to_focus;
|
||||||
e_border_button_bindings_grab_all();
|
e_border_button_bindings_grab_all();
|
||||||
e_config_save_queue();
|
e_config_save_queue();
|
||||||
|
return 1; /* Apply was OK */
|
||||||
}
|
}
|
||||||
|
|
||||||
/**--GUI--**/
|
/**--GUI--**/
|
||||||
static Evas_Object *
|
static Evas_Object *
|
||||||
_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata)
|
_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata)
|
||||||
{
|
{
|
||||||
|
/* generate the core widget layout for a basic dialog */
|
||||||
Evas_Object *o, *ob;
|
Evas_Object *o, *ob;
|
||||||
E_Radio_Group *rg;
|
E_Radio_Group *rg;
|
||||||
|
|
||||||
o = e_widget_list_add(evas, 0, 0);
|
o = e_widget_list_add(evas, 0, 0);
|
||||||
rg = e_widget_radio_group_new(&(cfdata->mode));
|
rg = e_widget_radio_group_new(&(cfdata->mode));
|
||||||
ob = e_widget_radio_add(evas, _("Click Window to Focus"), E_FOCUS_CLICK, rg);
|
ob = e_widget_radio_add(evas, _("Click Window to Focus"), E_FOCUS_CLICK, rg);
|
||||||
|
@ -131,6 +145,7 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata)
|
||||||
static Evas_Object *
|
static Evas_Object *
|
||||||
_advanced_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata)
|
_advanced_create_widgets(E_Config_Dialog *cfd, Evas *evas, CFData *cfdata)
|
||||||
{
|
{
|
||||||
|
/* generate the core widget layout for an advanced dialog */
|
||||||
Evas_Object *o, *ob, *of;
|
Evas_Object *o, *ob, *of;
|
||||||
E_Radio_Group *rg;
|
E_Radio_Group *rg;
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue