e17/evry: show plugin list in gadget settings

SVN revision: 63954
This commit is contained in:
Hannes Janetzek 2011-10-10 09:33:37 +00:00
parent a1aa9fe1de
commit d1caae1da8
3 changed files with 69 additions and 12 deletions

View File

@ -556,9 +556,10 @@ evry_gadget_shutdown(void)
struct _E_Config_Dialog_Data struct _E_Config_Dialog_Data
{ {
char *plugin; const char *plugin;
int hide_after_action; int hide_after_action;
int popup; int popup;
Evas_Object *list;
}; };
static void *_create_data(E_Config_Dialog *cfd); static void *_create_data(E_Config_Dialog *cfd);
@ -605,7 +606,7 @@ _create_data(E_Config_Dialog *cfd)
#define CP(_name) cfdata->_name = (gc->_name ? strdup(gc->_name) : NULL); #define CP(_name) cfdata->_name = (gc->_name ? strdup(gc->_name) : NULL);
#define C(_name) cfdata->_name = gc->_name; #define C(_name) cfdata->_name = gc->_name;
CP(plugin); /* CP(plugin); */
C(hide_after_action); C(hide_after_action);
C(popup); C(popup);
#undef CP #undef CP
@ -620,7 +621,7 @@ _free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
Instance *inst = cfd->data; Instance *inst = cfd->data;
inst->cfd = NULL; inst->cfd = NULL;
if (cfdata->plugin) free(cfdata->plugin); /* if (cfdata->plugin) free(cfdata->plugin); */
E_FREE(cfdata); E_FREE(cfdata);
} }
@ -630,6 +631,52 @@ _cb_button_settings(void *data __UNUSED__, void *data2 __UNUSED__)
/* evry_collection_conf_dialog(e_container_current_get(e_manager_current_get()), "Start"); */ /* evry_collection_conf_dialog(e_container_current_get(e_manager_current_get()), "Start"); */
} }
static void
_fill_list(Eina_List *plugins, Evas_Object *obj, E_Config_Dialog_Data *cfdata)
{
Evas *evas;
Evas_Coord w;
Eina_List *l;
Plugin_Config *pc;
int sel = 0, cnt = 1;
evas = evas_object_evas_get(obj);
evas_event_freeze(evas);
edje_freeze();
e_widget_ilist_freeze(obj);
e_widget_ilist_clear(obj);
e_widget_ilist_append(obj, NULL, _("All"), NULL, NULL, NULL);
EINA_LIST_FOREACH(plugins, l, pc)
{
if (!pc->plugin) continue;
e_widget_ilist_append(obj, NULL, pc->plugin->base.label, NULL, NULL, pc->name);
if (cfdata->plugin && !strcmp(pc->name, cfdata->plugin))
sel = cnt;
cnt++;
}
e_widget_ilist_selected_set(obj, sel);
e_widget_ilist_go(obj);
e_widget_size_min_get(obj, &w, NULL);
e_widget_size_min_set(obj, w > 180 ? w : 180, 140);
e_widget_ilist_thaw(obj);
edje_thaw();
evas_event_thaw(evas);
}
static void
_list_select_cb (void *data, Evas_Object *obj)
{
int sel = e_widget_ilist_selected_get(obj);
E_Config_Dialog_Data *cfdata = data;
e_widget_ilist_nth_data_get(obj, sel);
}
static Evas_Object * static Evas_Object *
_basic_create(E_Config_Dialog *cfd, Evas *e, E_Config_Dialog_Data *cfdata) _basic_create(E_Config_Dialog *cfd, Evas *e, E_Config_Dialog_Data *cfdata)
{ {
@ -639,9 +686,15 @@ _basic_create(E_Config_Dialog *cfd, Evas *e, E_Config_Dialog_Data *cfdata)
o = e_widget_list_add(e, 0, 0); o = e_widget_list_add(e, 0, 0);
of = e_widget_framelist_add(e, _("Plugin"), 0); of = e_widget_framelist_add(e, _("Plugin"), 0);
ow = e_widget_entry_add(e, &(cfdata->plugin), NULL, NULL, NULL); /* ow = e_widget_entry_add(e, &(cfdata->plugin), NULL, NULL, NULL);
e_widget_framelist_object_append(of, ow); * e_widget_framelist_object_append(of, ow); */
ow = e_widget_ilist_add(e, 24, 24, &cfdata->plugin);
/* e_widget_on_change_hook_set(ow, _list_select_cb, cfdata); */
_fill_list(evry_conf->conf_subjects, ow, cfdata);
e_widget_framelist_object_append(of, ow);
cfdata->list = ow;
ow = e_widget_button_add(e, _("Settings"), NULL, _cb_button_settings, inst, NULL); ow = e_widget_button_add(e, _("Settings"), NULL, _cb_button_settings, inst, NULL);
e_widget_framelist_object_append(of, ow); e_widget_framelist_object_append(of, ow);
@ -657,6 +710,7 @@ _basic_apply(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
Gadget_Config *gc = inst->cfg; Gadget_Config *gc = inst->cfg;
Evry_Plugin *p; Evry_Plugin *p;
Evas_Object *oo; Evas_Object *oo;
const char *plugin;
#define CP(_name) \ #define CP(_name) \
if (gc->_name) \ if (gc->_name) \
@ -664,7 +718,8 @@ _basic_apply(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
gc->_name = eina_stringshare_add(cfdata->_name); gc->_name = eina_stringshare_add(cfdata->_name);
#define C(_name) gc->_name = cfdata->_name; #define C(_name) gc->_name = cfdata->_name;
eina_stringshare_del(gc->plugin); \ eina_stringshare_del(gc->plugin); \
if (cfdata->plugin[0]) plugin = e_widget_ilist_selected_label_get(cfdata->list);
if (plugin && plugin[0])
gc->plugin = eina_stringshare_add(cfdata->plugin); gc->plugin = eina_stringshare_add(cfdata->plugin);
else else
gc->plugin = NULL; gc->plugin = NULL;

View File

@ -266,7 +266,9 @@ _fetch(Evry_Plugin *plugin, const char *input)
if (items) if (items)
{ {
eina_list_free(items); eina_list_free(items);
return EVRY_PLUGIN_HAS_ITEMS(p);
} }
/* 'text' and 'actions' are always loaded */ /* 'text' and 'actions' are always loaded */
else if ((subj_sel) && (eina_list_count(s->plugins) == 2)) else if ((subj_sel) && (eina_list_count(s->plugins) == 2))
{ {
@ -274,7 +276,7 @@ _fetch(Evry_Plugin *plugin, const char *input)
EVRY_PLUGIN_ITEM_APPEND(p, p->warning); EVRY_PLUGIN_ITEM_APPEND(p, p->warning);
} }
return EVRY_PLUGIN_HAS_ITEMS(p); return 0;
} }
static void static void

View File

@ -260,10 +260,10 @@ _evry_items_sort_func(const void *data1, const void *data2)
const Evry_Item *it1 = data1; const Evry_Item *it1 = data1;
const Evry_Item *it2 = data2; const Evry_Item *it2 = data2;
if (!((!_sort_flags) && /* if (!((!_sort_flags) &&
(it1->type == EVRY_TYPE_ACTION) && * (it1->type == EVRY_TYPE_ACTION) &&
(it2->type == EVRY_TYPE_ACTION))) * (it2->type == EVRY_TYPE_ACTION)))
{ * { */
/* only sort actions when there is input otherwise show default order */ /* only sort actions when there is input otherwise show default order */
if (((it1->type == EVRY_TYPE_ACTION) || (it1->subtype == EVRY_TYPE_ACTION)) && if (((it1->type == EVRY_TYPE_ACTION) || (it1->subtype == EVRY_TYPE_ACTION)) &&
@ -298,7 +298,7 @@ _evry_items_sort_func(const void *data1, const void *data2)
return 1; return 1;
} }
} }
} /* } */
if (_sort_flags) if (_sort_flags)
{ {