forked from enlightenment/enlightenment
e17/evry: show plugin list in gadget settings
SVN revision: 63954
This commit is contained in:
parent
a1aa9fe1de
commit
d1caae1da8
|
@ -556,9 +556,10 @@ evry_gadget_shutdown(void)
|
|||
|
||||
struct _E_Config_Dialog_Data
|
||||
{
|
||||
char *plugin;
|
||||
const char *plugin;
|
||||
int hide_after_action;
|
||||
int popup;
|
||||
Evas_Object *list;
|
||||
};
|
||||
|
||||
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 C(_name) cfdata->_name = gc->_name;
|
||||
CP(plugin);
|
||||
/* CP(plugin); */
|
||||
C(hide_after_action);
|
||||
C(popup);
|
||||
#undef CP
|
||||
|
@ -620,7 +621,7 @@ _free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
|
|||
Instance *inst = cfd->data;
|
||||
|
||||
inst->cfd = NULL;
|
||||
if (cfdata->plugin) free(cfdata->plugin);
|
||||
/* if (cfdata->plugin) free(cfdata->plugin); */
|
||||
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"); */
|
||||
}
|
||||
|
||||
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 *
|
||||
_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);
|
||||
|
||||
of = e_widget_framelist_add(e, _("Plugin"), 0);
|
||||
ow = e_widget_entry_add(e, &(cfdata->plugin), NULL, NULL, NULL);
|
||||
e_widget_framelist_object_append(of, ow);
|
||||
/* ow = e_widget_entry_add(e, &(cfdata->plugin), NULL, NULL, NULL);
|
||||
* 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);
|
||||
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;
|
||||
Evry_Plugin *p;
|
||||
Evas_Object *oo;
|
||||
const char *plugin;
|
||||
|
||||
#define CP(_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);
|
||||
#define C(_name) gc->_name = cfdata->_name;
|
||||
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);
|
||||
else
|
||||
gc->plugin = NULL;
|
||||
|
|
|
@ -266,7 +266,9 @@ _fetch(Evry_Plugin *plugin, const char *input)
|
|||
if (items)
|
||||
{
|
||||
eina_list_free(items);
|
||||
return EVRY_PLUGIN_HAS_ITEMS(p);
|
||||
}
|
||||
|
||||
/* 'text' and 'actions' are always loaded */
|
||||
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);
|
||||
}
|
||||
|
||||
return EVRY_PLUGIN_HAS_ITEMS(p);
|
||||
return 0;
|
||||
}
|
||||
|
||||
static void
|
||||
|
|
|
@ -260,10 +260,10 @@ _evry_items_sort_func(const void *data1, const void *data2)
|
|||
const Evry_Item *it1 = data1;
|
||||
const Evry_Item *it2 = data2;
|
||||
|
||||
if (!((!_sort_flags) &&
|
||||
(it1->type == EVRY_TYPE_ACTION) &&
|
||||
(it2->type == EVRY_TYPE_ACTION)))
|
||||
{
|
||||
/* if (!((!_sort_flags) &&
|
||||
* (it1->type == EVRY_TYPE_ACTION) &&
|
||||
* (it2->type == EVRY_TYPE_ACTION)))
|
||||
* { */
|
||||
/* only sort actions when there is input otherwise show default order */
|
||||
|
||||
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;
|
||||
}
|
||||
}
|
||||
}
|
||||
/* } */
|
||||
|
||||
if (_sort_flags)
|
||||
{
|
||||
|
|
Loading…
Reference in New Issue