add config menu in settings
This commit is contained in:
parent
8110171858
commit
f87c66b44e
|
@ -11,7 +11,7 @@ pkgdir = $(module_dir)/$(PACKAGE)/$(MODULE_ARCH)
|
|||
pkg_LTLIBRARIES = module.la
|
||||
module_la_SOURCES = e_mod_main.h \
|
||||
e_mod_main.c \
|
||||
e_mod_config.c \
|
||||
ds_config.c \
|
||||
maximize.c \
|
||||
moveresize.c \
|
||||
desksanity.c
|
||||
|
|
|
@ -0,0 +1,65 @@
|
|||
#include "e_mod_main.h"
|
||||
|
||||
static E_Int_Menu_Augmentation *maug = NULL;
|
||||
|
||||
|
||||
static void
|
||||
_ds_menu_ruler(void *data EINA_UNUSED, E_Menu *m EINA_UNUSED, E_Menu_Item *mi)
|
||||
{
|
||||
ds_config->disable_ruler = mi->toggle;
|
||||
if (ds_config->disable_ruler)
|
||||
mr_shutdown();
|
||||
else
|
||||
mr_init();
|
||||
}
|
||||
|
||||
static void
|
||||
_ds_menu_maximize(void *data EINA_UNUSED, E_Menu *m EINA_UNUSED, E_Menu_Item *mi)
|
||||
{
|
||||
ds_config->disable_maximize = mi->toggle;
|
||||
if (ds_config->disable_maximize)
|
||||
maximize_shutdown();
|
||||
else
|
||||
maximize_init();
|
||||
}
|
||||
|
||||
static void
|
||||
_ds_menu_add(void *data EINA_UNUSED, E_Menu *m)
|
||||
{
|
||||
E_Menu_Item *mi;
|
||||
E_Menu *subm;
|
||||
|
||||
mi = e_menu_item_new(m);
|
||||
e_menu_item_label_set(mi, D_("Desksanity"));
|
||||
e_menu_item_icon_edje_set(mi, mod->edje_file, "icon");
|
||||
|
||||
subm = e_menu_new();
|
||||
e_menu_title_set(subm, D_("Options"));
|
||||
e_menu_item_submenu_set(mi, subm);
|
||||
|
||||
mi = e_menu_item_new(subm);
|
||||
e_menu_item_label_set(mi, D_("Disable Move/Resize Ruler"));
|
||||
e_menu_item_check_set(mi, 1);
|
||||
e_menu_item_toggle_set(mi, ds_config->disable_ruler);
|
||||
e_menu_item_callback_set(mi, _ds_menu_ruler, NULL);
|
||||
|
||||
mi = e_menu_item_new(subm);
|
||||
e_menu_item_label_set(mi, D_("Disable Maximize Effects"));
|
||||
e_menu_item_check_set(mi, 1);
|
||||
e_menu_item_toggle_set(mi, ds_config->disable_maximize);
|
||||
e_menu_item_callback_set(mi, _ds_menu_maximize, NULL);
|
||||
}
|
||||
|
||||
EINTERN void
|
||||
ds_config_init(void)
|
||||
{
|
||||
maug = e_int_menus_menu_augmentation_add_sorted
|
||||
("config/1", D_("Desksanity"), _ds_menu_add, NULL, NULL, NULL);
|
||||
}
|
||||
|
||||
EINTERN void
|
||||
ds_config_shutdown(void)
|
||||
{
|
||||
e_int_menus_menu_augmentation_del("config/1", maug);
|
||||
maug = NULL;
|
||||
}
|
|
@ -1,244 +0,0 @@
|
|||
#include "e_mod_main.h"
|
||||
#if 0
|
||||
|
||||
static void
|
||||
_free_data(E_Config_Dialog *cfd EINA_UNUSED, E_Config_Dialog_Data *cfdata EINA_UNUSED)
|
||||
{
|
||||
mod->cfd = NULL;
|
||||
mod->label = mod->cfd_list[0] = mod->cfd_list[1] = NULL;
|
||||
}
|
||||
/*
|
||||
static void *
|
||||
_create_data(E_Config_Dialog *cfd EINA_UNUSED)
|
||||
{
|
||||
return NULL;
|
||||
}
|
||||
|
||||
static int
|
||||
_basic_apply(E_Config_Dialog *cfd EINA_UNUSED, E_Config_Dialog_Data *cfdata EINA_UNUSED)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
|
||||
static int
|
||||
_basic_check_changed(E_Config_Dialog *cfd EINA_UNUSED, E_Config_Dialog_Data *cfdata EINA_UNUSED)
|
||||
{
|
||||
return 0;
|
||||
}
|
||||
*/
|
||||
|
||||
static void
|
||||
_obj_del(Echievement *ec, Evas *e EINA_UNUSED, Evas_Object *obj, void *event_info EINA_UNUSED)
|
||||
{
|
||||
if (obj == ec->dialog.icon)
|
||||
ec->dialog.icon = NULL;
|
||||
else
|
||||
ec->dialog.label = NULL;
|
||||
}
|
||||
|
||||
static Evas_Object *
|
||||
_item_create(Evas *evas, Echievement *ec, Eina_Bool save)
|
||||
{
|
||||
Evas_Object *table, *icon, *label;
|
||||
char progress[128];
|
||||
unsigned int goal, counter;
|
||||
|
||||
etrophy_trophy_goal_get(ec->trophy, &goal, &counter);
|
||||
table = e_widget_frametable_add(evas, D_(etrophy_trophy_name_get(ec->trophy)), 1);
|
||||
|
||||
icon = e_widget_image_add_from_file(evas, PACKAGE_DATA_DIR "/trophy.png",
|
||||
64, 64);
|
||||
if (save) ec->dialog.icon = icon;
|
||||
evas_object_event_callback_add(icon, EVAS_CALLBACK_DEL, (Evas_Object_Event_Cb)_obj_del, ec);
|
||||
e_widget_frametable_object_append(table, icon, 0, 0, 1, 2, 1, 1, 1, 0);
|
||||
label = e_widget_label_add(evas, D_(etrophy_trophy_description_get(ec->trophy)));
|
||||
e_widget_frametable_object_append(table, label, 1, 0, 3, 1, 1, 1, 1, 0);
|
||||
|
||||
if (etrophy_trophy_earned_get(ec->trophy))
|
||||
{
|
||||
char date[256];
|
||||
char buf[512];
|
||||
time_t t0;
|
||||
|
||||
t0 = etrophy_trophy_date_get(ec->trophy);
|
||||
strftime(date, sizeof(date), "%d %B %Y - %r", localtime(&t0));
|
||||
snprintf(buf, sizeof(buf), D_("Achieved: %s"), date);
|
||||
label = e_widget_label_add(evas, buf);
|
||||
}
|
||||
else if (goal < 2)
|
||||
label = e_widget_label_add(evas, D_("Not achieved"));
|
||||
else
|
||||
{
|
||||
snprintf(progress, sizeof(progress), D_("Progress: %u/%u"), counter, goal);
|
||||
label = e_widget_label_add(evas, progress);
|
||||
}
|
||||
if (save) ec->dialog.label = label;
|
||||
evas_object_event_callback_add(label, EVAS_CALLBACK_DEL, (Evas_Object_Event_Cb)_obj_del, ec);
|
||||
e_widget_frametable_object_append(table, label, 1, 1, 3, 1, 1, 1, 1, 0);
|
||||
|
||||
return table;
|
||||
}
|
||||
|
||||
static Evas_Object *
|
||||
_basic_create(E_Config_Dialog *cfd EINA_UNUSED, Evas *evas, E_Config_Dialog_Data *cfdata EINA_UNUSED)
|
||||
{
|
||||
Evas_Object *toolbook, *list, *item, *sf;
|
||||
Echievement *ec;
|
||||
int mw, mh, mww;
|
||||
|
||||
toolbook = e_widget_toolbook_add(evas, 48 * e_scale, 48 * e_scale);
|
||||
|
||||
/* FIXME it should be scrollable and all initial items should
|
||||
be visible */
|
||||
mod->cfd_list[0] = list = e_widget_list_add(evas, 1, 0);
|
||||
EINA_INLIST_FOREACH(EINA_INLIST_GET(mod->trophies_list), ec)
|
||||
{
|
||||
if (!etrophy_trophy_earned_get(ec->trophy)) continue;
|
||||
item = _item_create(evas, ec, EINA_FALSE);
|
||||
e_widget_list_object_append(list, item, 1, 1, 0.5);
|
||||
}
|
||||
e_widget_size_min_get(list, &mw, &mh);
|
||||
|
||||
if (mw < 320) mw = 320;
|
||||
if (mh < 220) mh = 220;
|
||||
|
||||
evas_object_resize(list, mw, mh);
|
||||
sf = e_widget_scrollframe_simple_add(evas, list);
|
||||
e_widget_size_min_set(sf, 320, 220);
|
||||
e_widget_toolbook_page_append(toolbook, NULL, D_("My Trophies"),
|
||||
sf, 1, 1, 1, 1, 0.5, 0.0);
|
||||
|
||||
mod->cfd_list[1] = list = e_widget_list_add(evas, 1, 0);
|
||||
|
||||
EINA_INLIST_FOREACH(EINA_INLIST_GET(mod->trophies_list), ec)
|
||||
{
|
||||
if ((!etrophy_trophy_earned_get(ec->trophy)) && (!etrophy_trophy_visibility_get(ec->trophy))) continue;
|
||||
item = _item_create(evas, ec, EINA_TRUE);
|
||||
e_widget_list_object_append(list, item, 1, 1, 0.5);
|
||||
}
|
||||
e_widget_size_min_get(list, &mww, &mh);
|
||||
|
||||
if (mww < mw) mww = mw;
|
||||
if (mh < 220) mh = 220;
|
||||
|
||||
evas_object_resize(list, mww, mh);
|
||||
sf = e_widget_scrollframe_simple_add(evas, list);
|
||||
e_widget_size_min_set(sf, 320, 220);
|
||||
e_widget_toolbook_page_append(toolbook, NULL, D_("All Trophies"),
|
||||
sf, 1, 1, 1, 1, 0.5, 0.0);
|
||||
|
||||
e_widget_toolbook_page_show(toolbook, 0);
|
||||
list = e_widget_list_add(evas, 0, 0);
|
||||
e_widget_list_object_append(list, toolbook, 1, 1, 0.5);
|
||||
{
|
||||
char buf[1024];
|
||||
unsigned score = etrophy_gamescore_trophies_points_get(ds_config->gs);
|
||||
|
||||
/* FIXME: this can look better */
|
||||
snprintf(buf, sizeof(buf), DP_("%u Echievement Point", "%u Echievement Points", score), score);
|
||||
mod->label = item = e_widget_label_add(evas, buf);
|
||||
e_widget_list_object_append(list, item, 0, 0, 0.5);
|
||||
}
|
||||
return list;
|
||||
}
|
||||
|
||||
static void
|
||||
_totals_update(void)
|
||||
{
|
||||
char buf[1024];
|
||||
unsigned score = etrophy_gamescore_trophies_points_get(ds_config->gs);
|
||||
|
||||
snprintf(buf, sizeof(buf), DP_("%u Echievement Point", "%u Echievement Points", score), score);
|
||||
e_widget_label_text_set(mod->label, buf);
|
||||
}
|
||||
|
||||
E_Config_Dialog *
|
||||
e_int_config_echievements(E_Container *con, const char *params EINA_UNUSED)
|
||||
{
|
||||
E_Config_Dialog *cfd = NULL;
|
||||
E_Config_Dialog_View *v = NULL;
|
||||
char buf[4096];
|
||||
|
||||
if (e_config_dialog_find("Echievements", "extensions/echievements"))
|
||||
return NULL;
|
||||
|
||||
mod->obj_del_cb = (Evas_Object_Event_Cb)_obj_del;
|
||||
v = E_NEW(E_Config_Dialog_View, 1);
|
||||
v->free_cfdata = _free_data;
|
||||
v->basic.create_widgets = _basic_create;
|
||||
/*
|
||||
v->create_cfdata = _create_data;
|
||||
v->basic.apply_cfdata = _basic_apply;
|
||||
v->basic.check_changed = _basic_check_changed;
|
||||
*/
|
||||
snprintf(buf, sizeof(buf), "%s/e-module-echievements.edj",
|
||||
mod->module->dir);
|
||||
|
||||
cfd = e_config_dialog_new(con, D_("Echievements"), "Echievements",
|
||||
"extensions/echievements", buf, 0, v, NULL);
|
||||
|
||||
e_dialog_resizable_set(cfd->dia, 1);
|
||||
mod->cfd = cfd;
|
||||
return cfd;
|
||||
}
|
||||
|
||||
EINTERN void
|
||||
ech_cfg_ech_update(Echievement *ec)
|
||||
{
|
||||
char progress[128];
|
||||
unsigned int goal, counter;
|
||||
|
||||
if (!mod->cfd) return;
|
||||
if ((!ec->dialog.icon) || (!ec->dialog.label)) return;
|
||||
etrophy_trophy_goal_get(ec->trophy, &goal, &counter);
|
||||
if (etrophy_trophy_earned_get(ec->trophy))
|
||||
{
|
||||
char date[256];
|
||||
char buf[512];
|
||||
time_t t0;
|
||||
|
||||
t0 = etrophy_trophy_date_get(ec->trophy);
|
||||
strftime(date, sizeof(date), "%d %B %Y - %r", localtime(&t0));
|
||||
snprintf(buf, sizeof(buf), D_("Achieved: %s"), date);
|
||||
e_widget_label_text_set(ec->dialog.label, buf);
|
||||
}
|
||||
else if (goal < 2)
|
||||
e_widget_label_text_set(ec->dialog.label, D_("Not achieved"));
|
||||
else
|
||||
{
|
||||
snprintf(progress, sizeof(progress), D_("Progress: %u/%u"), counter, goal);
|
||||
e_widget_label_text_set(ec->dialog.label, progress);
|
||||
}
|
||||
e_widget_frametable_object_repack(e_widget_parent_get(ec->dialog.label), ec->dialog.label, 1, 1, 3, 1, 1, 1, 1, 0);
|
||||
_totals_update();
|
||||
}
|
||||
|
||||
EINTERN void
|
||||
ech_cfg_ech_add(Echievement *ec)
|
||||
{
|
||||
Evas *e;
|
||||
Evas_Object *item;
|
||||
int mh;
|
||||
int w;
|
||||
|
||||
if (!mod->cfd) return;
|
||||
/* use "all trophies" list current width
|
||||
* since it's guaranteed to be correct for the moment
|
||||
*/
|
||||
evas_object_geometry_get(mod->cfd_list[1], NULL, NULL, &w, NULL);
|
||||
e = evas_object_evas_get(mod->cfd_list[0]);
|
||||
item = _item_create(e, ec, EINA_FALSE);
|
||||
e_widget_list_object_append(mod->cfd_list[0], item, 1, 1, 0.5);
|
||||
e_widget_size_min_get(mod->cfd_list[0], NULL, &mh);
|
||||
|
||||
evas_object_resize(mod->cfd_list[0], w, mh);
|
||||
|
||||
if (ec->dialog.icon || ec->dialog.label) return;
|
||||
|
||||
item = _item_create(e, ec, EINA_TRUE);
|
||||
e_widget_list_object_append(mod->cfd_list[1], item, 1, 1, 0.5);
|
||||
e_widget_size_min_get(mod->cfd_list[1], NULL, &mh);
|
||||
evas_object_resize(mod->cfd_list[1], w, mh);
|
||||
_totals_update();
|
||||
}
|
||||
#endif
|
|
@ -2,7 +2,6 @@
|
|||
|
||||
EAPI E_Module_Api e_modapi = {E_MODULE_API_VERSION, "Desksanity"};
|
||||
static E_Config_DD *conf_edd = NULL;
|
||||
static Eina_List *handlers = NULL;
|
||||
|
||||
EINTERN Mod *mod = NULL;
|
||||
EINTERN Config *ds_config = NULL;
|
||||
|
@ -16,46 +15,45 @@ _e_mod_ds_config_load(void)
|
|||
#define T Config
|
||||
#define D conf_edd
|
||||
E_CONFIG_VAL(D, T, config_version, UINT);
|
||||
E_CONFIG_VAL(D, T, disable_ruler, UCHAR);
|
||||
E_CONFIG_VAL(D, T, disable_maximize, UCHAR);
|
||||
|
||||
//ds_config = e_config_domain_load("module.desksanity", conf_edd);
|
||||
ds_config = e_config_domain_load("module.desksanity", conf_edd);
|
||||
if (ds_config)
|
||||
{
|
||||
if (!e_util_module_config_check("Desksanity", ds_config->config_version, MOD_CONFIG_FILE_VERSION))
|
||||
{}
|
||||
E_FREE(ds_config);
|
||||
}
|
||||
|
||||
if (!ds_config)
|
||||
{
|
||||
ds_config = E_NEW(Config, 1);
|
||||
ds_config->config_version = (MOD_CONFIG_FILE_EPOCH << 16);
|
||||
}
|
||||
ds_config = E_NEW(Config, 1);
|
||||
ds_config->config_version = MOD_CONFIG_FILE_VERSION;
|
||||
}
|
||||
|
||||
EAPI void *
|
||||
e_modapi_init(E_Module *m)
|
||||
{
|
||||
char buf[4096];
|
||||
char buf[PATH_MAX];
|
||||
|
||||
bindtextdomain(PACKAGE, LOCALEDIR);
|
||||
bind_textdomain_codeset(PACKAGE, "UTF-8");
|
||||
|
||||
snprintf(buf, sizeof(buf), "%s/e-module-desksanity.edj", m->dir);
|
||||
elm_theme_overlay_add(NULL, buf);
|
||||
//
|
||||
//e_configure_registry_category_add("appearance", 80, D_("Look"),
|
||||
//NULL, "preferences-look");
|
||||
//e_configure_registry_item_add("extensions/desksanity", 110, D_("Echievements"),
|
||||
//NULL, buf, e_int_config_desksanity);
|
||||
|
||||
efx_init();
|
||||
_e_mod_ds_config_load();
|
||||
|
||||
mod = E_NEW(Mod, 1);
|
||||
mod->module = m;
|
||||
mod->edje_file = eina_stringshare_add(buf);
|
||||
|
||||
ds_config_init();
|
||||
ds_init();
|
||||
mr_init();
|
||||
maximize_init();
|
||||
if (!ds_config->disable_ruler)
|
||||
mr_init();
|
||||
if (!ds_config->disable_maximize)
|
||||
maximize_init();
|
||||
|
||||
return m;
|
||||
}
|
||||
|
@ -63,19 +61,17 @@ e_modapi_init(E_Module *m)
|
|||
EAPI int
|
||||
e_modapi_shutdown(E_Module *m EINA_UNUSED)
|
||||
{
|
||||
e_configure_registry_item_del("appearance/desksanity");
|
||||
|
||||
e_configure_registry_category_del("extensions");
|
||||
|
||||
E_FREE_FUNC(mod->cfd, e_object_del);
|
||||
maximize_shutdown();
|
||||
mr_shutdown();
|
||||
if (!ds_config->disable_maximize)
|
||||
maximize_shutdown();
|
||||
if (!ds_config->disable_ruler)
|
||||
mr_shutdown();
|
||||
ds_shutdown();
|
||||
//e_config_domain_save("module.desksanity", conf_edd, ds_config);
|
||||
ds_config_shutdown();
|
||||
e_config_domain_save("module.desksanity", conf_edd, ds_config);
|
||||
E_FREE(ds_config);
|
||||
E_CONFIG_DD_FREE(conf_edd);
|
||||
eina_stringshare_del(mod->edje_file);
|
||||
E_FREE(mod);
|
||||
E_FREE_LIST(handlers, ecore_event_handler_del);
|
||||
//efx_shutdown(); broken...
|
||||
return 1;
|
||||
}
|
||||
|
@ -83,7 +79,7 @@ e_modapi_shutdown(E_Module *m EINA_UNUSED)
|
|||
EAPI int
|
||||
e_modapi_save(E_Module *m EINA_UNUSED)
|
||||
{
|
||||
//e_config_domain_save("module.desksanity", conf_edd, ds_config);
|
||||
e_config_domain_save("module.desksanity", conf_edd, ds_config);
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
|
|
@ -35,6 +35,8 @@ typedef struct Mod
|
|||
typedef struct Config
|
||||
{
|
||||
unsigned int config_version;
|
||||
Eina_Bool disable_ruler;
|
||||
Eina_Bool disable_maximize;
|
||||
} Config;
|
||||
|
||||
extern Mod *mod;
|
||||
|
@ -49,4 +51,7 @@ EINTERN void mr_init(void);
|
|||
EINTERN void maximize_init(void);
|
||||
EINTERN void maximize_shutdown(void);
|
||||
|
||||
|
||||
EINTERN void ds_config_init(void);
|
||||
EINTERN void ds_config_shutdown(void);
|
||||
#endif
|
||||
|
|
Loading…
Reference in New Issue