'everything' added configuration for triggers and views per plugin.

SVN revision: 48256
This commit is contained in:
Hannes Janetzek 2010-04-23 20:48:22 +00:00
parent 2216ee49df
commit 6a858f10db
6 changed files with 312 additions and 190 deletions

View File

@ -354,28 +354,15 @@ struct _Config
struct _Plugin_Config struct _Plugin_Config
{ {
const char *name; const char *name;
int loaded;
int enabled; int enabled;
/* minimum input chars to query this source */
int min_query;
int priority; int priority;
const char *trigger; const char *trigger;
int trigger_only;
Evry_Plugin *plugin; int view_mode;
Eina_Hash *settings;
};
struct _Plugin_Setting
{
int type;
char *description;
char *val; Evry_Plugin *plugin;
}; };
struct _History_Entry struct _History_Entry
@ -430,6 +417,7 @@ EAPI Eina_Bool evry_util_module_config_check(const char *module_name, int conf,
/* e_mod_main.c */ /* e_mod_main.c */
/* set plugin trigger and view mode first before register !*/
EAPI void evry_plugin_register(Evry_Plugin *p, int priority); EAPI void evry_plugin_register(Evry_Plugin *p, int priority);
EAPI void evry_plugin_unregister(Evry_Plugin *p); EAPI void evry_plugin_unregister(Evry_Plugin *p);
EAPI void evry_action_register(Evry_Action *act, int priority); EAPI void evry_action_register(Evry_Action *act, int priority);

View File

@ -12,7 +12,7 @@
/* #undef DBG /* #undef DBG
* #define DBG(...) ERR(__VA_ARGS__) */ * #define DBG(...) ERR(__VA_ARGS__) */
#define CONFIG_VERSION 10 #define CONFIG_VERSION 12
/* actual module specifics */ /* actual module specifics */
static void _e_mod_action_cb(E_Object *obj, const char *params); static void _e_mod_action_cb(E_Object *obj, const char *params);
@ -171,28 +171,17 @@ _config_init()
{ {
#undef T #undef T
#undef D #undef D
#define T Plugin_Setting
#define D plugin_setting_edd
plugin_setting_edd = E_CONFIG_DD_NEW("Plugin_Setting", Plugin_Setting);
E_CONFIG_VAL(D, T, type, INT);
E_CONFIG_VAL(D, T, description, STR);
E_CONFIG_VAL(D, T, val, STR);
#undef T
#undef D
#define T Plugin_Config #define T Plugin_Config
#define D plugin_conf_edd #define D plugin_conf_edd
plugin_conf_edd = E_CONFIG_DD_NEW("Plugin_Config", Plugin_Config); plugin_conf_edd = E_CONFIG_DD_NEW("Plugin_Config", Plugin_Config);
E_CONFIG_VAL(D, T, name, STR); E_CONFIG_VAL(D, T, name, STR);
E_CONFIG_VAL(D, T, trigger, STR);
E_CONFIG_VAL(D, T, min_query, INT);
E_CONFIG_VAL(D, T, loaded, INT);
E_CONFIG_VAL(D, T, enabled, INT); E_CONFIG_VAL(D, T, enabled, INT);
E_CONFIG_VAL(D, T, priority, INT); E_CONFIG_VAL(D, T, priority, INT);
E_CONFIG_HASH(D, T, settings, plugin_setting_edd); E_CONFIG_VAL(D, T, trigger, STR);
E_CONFIG_VAL(D, T, trigger_only, INT);
E_CONFIG_VAL(D, T, view_mode, INT);
#undef T #undef T
#undef D #undef D
#define T Evry_Config #define T Evry_Config
#define D conf_edd #define D conf_edd
conf_edd = E_CONFIG_DD_NEW("Config", Evry_Config); conf_edd = E_CONFIG_DD_NEW("Config", Evry_Config);
@ -238,10 +227,35 @@ _config_init()
if (evry_conf && evry_conf->version == 9) if (evry_conf && evry_conf->version == 9)
{ {
evry_conf->first_run = EINA_TRUE; evry_conf->first_run = EINA_TRUE;
evry_conf->version = CONFIG_VERSION; evry_conf->version = 11;
} }
if (evry_conf && evry_conf->version == 11)
{
Plugin_Config *pc;
EINA_LIST_FREE(evry_conf->conf_subjects, pc)
{
if (pc->name) eina_stringshare_del(pc->name);
if (pc->trigger) eina_stringshare_del(pc->trigger);
E_FREE(pc);
}
EINA_LIST_FREE(evry_conf->conf_actions, pc)
{
if (pc->name) eina_stringshare_del(pc->name);
if (pc->trigger) eina_stringshare_del(pc->trigger);
E_FREE(pc);
}
EINA_LIST_FREE(evry_conf->conf_objects, pc)
{
if (pc->name) eina_stringshare_del(pc->name);
if (pc->trigger) eina_stringshare_del(pc->trigger);
E_FREE(pc);
}
evry_conf->version = CONFIG_VERSION;
}
if (evry_conf && evry_conf->version != CONFIG_VERSION) if (evry_conf && evry_conf->version != CONFIG_VERSION)
{ {
_config_free(); _config_free();
@ -282,21 +296,21 @@ _config_free(void)
eina_stringshare_del(evry_conf->cmd_terminal); eina_stringshare_del(evry_conf->cmd_terminal);
EINA_LIST_FREE(evry_conf->conf_subjects, pc) EINA_LIST_FREE(evry_conf->conf_subjects, pc)
{ {
if (pc->name) eina_stringshare_del(pc->name); if (pc->name) eina_stringshare_del(pc->name);
if (pc->trigger) eina_stringshare_del(pc->trigger); if (pc->trigger) eina_stringshare_del(pc->trigger);
E_FREE(pc); E_FREE(pc);
} }
EINA_LIST_FREE(evry_conf->conf_actions, pc) EINA_LIST_FREE(evry_conf->conf_actions, pc)
{ {
if (pc->name) eina_stringshare_del(pc->name); if (pc->name) eina_stringshare_del(pc->name);
if (pc->trigger) eina_stringshare_del(pc->trigger); if (pc->trigger) eina_stringshare_del(pc->trigger);
E_FREE(pc); E_FREE(pc);
} }
EINA_LIST_FREE(evry_conf->conf_objects, pc) EINA_LIST_FREE(evry_conf->conf_objects, pc)
{ {
if (pc->name) eina_stringshare_del(pc->name); if (pc->name) eina_stringshare_del(pc->name);
if (pc->trigger) eina_stringshare_del(pc->trigger); if (pc->trigger) eina_stringshare_del(pc->trigger);
E_FREE(pc); E_FREE(pc);
} }
E_FREE(evry_conf); E_FREE(evry_conf);
} }
@ -509,11 +523,18 @@ evry_plugin_register(Evry_Plugin *p, int priority)
pc = E_NEW(Plugin_Config, 1); pc = E_NEW(Plugin_Config, 1);
pc->name = eina_stringshare_add(p->name); pc->name = eina_stringshare_add(p->name);
pc->enabled = 1; pc->enabled = 1;
pc->priority = priority ? priority : 100;; pc->priority = priority ? priority : 100;
pc->view_mode = p->view_mode;
if (p->trigger)
{
pc->trigger = eina_stringshare_add(p->trigger);
pc->trigger_only = 1;
}
pc->plugin = p; pc->plugin = p;
confs = eina_list_append(confs, pc); confs = eina_list_append(confs, pc);
} }
p->config = pc; p->config = pc;
evry_conf->plugins = eina_list_sort(evry_conf->plugins, evry_conf->plugins = eina_list_sort(evry_conf->plugins,
eina_list_count(evry_conf->plugins), eina_list_count(evry_conf->plugins),

View File

@ -1901,30 +1901,38 @@ _evry_matches_update(Evry_Selector *sel, int async)
if (!s->cur_plugins && input) if (!s->cur_plugins && input)
{ {
int len_trigger = 0; int len_trigger = 0;
int len_inp = strlen(s->inp);
EINA_LIST_FOREACH(s->plugins, l, p) EINA_LIST_FOREACH(s->plugins, l, p)
{ {
/* input matches plugin trigger? */ /* input matches plugin trigger? */
if (!p->trigger) continue; if (!p->config->trigger) continue;
int len = strlen(p->trigger); int len = strlen(p->config->trigger);
if (len_trigger && len != len_trigger) if (len_trigger && len != len_trigger)
continue; continue;
if ((strlen(s->inp) >= len) && if ((len_inp >= len) &&
(!strncmp(s->inp, p->trigger, len))) (!strncmp(s->inp, p->config->trigger, len)))
{ {
len_trigger = len; len_trigger = len;
s->cur_plugins = eina_list_append(s->cur_plugins, p); s->cur_plugins = eina_list_append(s->cur_plugins, p);
p->fetch(p, s->input + len); if(len_inp == len)
p->fetch(p, NULL);
else
p->fetch(p, s->input + len);
} }
} }
if (s->cur_plugins) if (s->cur_plugins)
{ {
s->trigger_active = EINA_TRUE; s->trigger_active = EINA_TRUE;
s->inp[0] = '>'; /* replace trigger with indicator */
s->inp[1] = '\0'; if (len_trigger > 1)
s->input = s->inp + 1; {
s->inp[0] = '>';
s->inp[1] = '\0';
}
s->input = s->inp + 1;
_evry_update_text_label(s); _evry_update_text_label(s);
} }
} }
@ -1935,7 +1943,9 @@ _evry_matches_update(Evry_Selector *sel, int async)
EINA_LIST_FOREACH(s->plugins, l, p) EINA_LIST_FOREACH(s->plugins, l, p)
{ {
if (!win->plugin_dedicated && p->trigger) if ((!win->plugin_dedicated) &&
(p->config->trigger_only) &&
(p->config->trigger))
continue; continue;
if (p == sel->aggregator) if (p == sel->aggregator)
continue; continue;

View File

@ -5,6 +5,27 @@ static void _free_data (E_Config_Dialog *cfd, E_Config_Dia
static int _basic_apply_data (E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata); static int _basic_apply_data (E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
static Evas_Object *_basic_create_widgets (E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata); static Evas_Object *_basic_create_widgets (E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata);
typedef struct _Plugin_Page Plugin_Page;
struct _Plugin_Page
{
Evas_Object *list;
Evas_Object *o_trigger;
Evas_Object *o_trigger_only;
E_Radio_Group *view_rg;
Evas_Object *o_view_default;
Evas_Object *o_view_list;
Evas_Object *o_view_detail;
Evas_Object *o_view_thumb;
Eina_List *configs;
char *trigger;
int trigger_only;
int view_mode;
Plugin_Config *cur;
} ;
struct _E_Config_Dialog_Data struct _E_Config_Dialog_Data
{ {
@ -26,14 +47,8 @@ struct _E_Config_Dialog_Data
int cycle_mode; int cycle_mode;
int history_sort_mode; int history_sort_mode;
Evas_Object *l_subject;
Evas_Object *l_action;
Evas_Object *l_object;
Eina_List *p_subject; Plugin_Page page[3];
Eina_List *p_action;
Eina_List *p_object;
}; };
@ -78,9 +93,9 @@ _fill_data(E_Config_Dialog_Data *cfdata)
C(scroll_speed); C(scroll_speed);
#undef C #undef C
cfdata->p_subject = eina_list_clone(evry_conf->conf_subjects); cfdata->page[0].configs = eina_list_clone(evry_conf->conf_subjects);
cfdata->p_action = eina_list_clone(evry_conf->conf_actions); cfdata->page[1].configs = eina_list_clone(evry_conf->conf_actions);
cfdata->p_object = eina_list_clone(evry_conf->conf_objects); cfdata->page[2].configs = eina_list_clone(evry_conf->conf_objects);
if (evry_conf->cmd_terminal) if (evry_conf->cmd_terminal)
cfdata->cmd_terminal = strdup(evry_conf->cmd_terminal); cfdata->cmd_terminal = strdup(evry_conf->cmd_terminal);
@ -102,27 +117,20 @@ _create_data(E_Config_Dialog *cfd __UNUSED__)
static void static void
_free_data(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfdata) _free_data(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfdata)
{ {
if (cfdata->p_subject) eina_list_free(cfdata->p_subject); if (cfdata->page[0].configs) eina_list_free(cfdata->page[0].configs);
if (cfdata->p_action) eina_list_free(cfdata->p_action); if (cfdata->page[1].configs) eina_list_free(cfdata->page[1].configs);
if (cfdata->p_object) eina_list_free(cfdata->p_object); if (cfdata->page[2].configs) eina_list_free(cfdata->page[2].configs);
E_FREE(cfdata->cmd_terminal); E_FREE(cfdata->cmd_terminal);
E_FREE(cfdata->cmd_sudo); E_FREE(cfdata->cmd_sudo);
E_FREE(cfdata); E_FREE(cfdata);
} }
/* static int
* _evry_cb_plugin_sort(const void *data1, const void *data2)
* {
* const Evry_Plugin *p1 = data1;
* const Evry_Plugin *p2 = data2;
* return p1->config->priority - p2->config->priority;
* } */
static int static int
_basic_apply_data(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfdata) _basic_apply_data(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfdata)
{ {
int i;
#define C(_name) evry_conf->_name = cfdata->_name #define C(_name) evry_conf->_name = cfdata->_name
C(height); C(height);
C(width); C(width);
@ -146,13 +154,27 @@ _basic_apply_data(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfdata)
if (evry_conf->conf_actions) eina_list_free(evry_conf->conf_actions); if (evry_conf->conf_actions) eina_list_free(evry_conf->conf_actions);
if (evry_conf->conf_objects) eina_list_free(evry_conf->conf_objects); if (evry_conf->conf_objects) eina_list_free(evry_conf->conf_objects);
evry_conf->conf_subjects = cfdata->p_subject; evry_conf->conf_subjects = eina_list_clone(cfdata->page[0].configs);
evry_conf->conf_actions = cfdata->p_action; evry_conf->conf_actions = eina_list_clone(cfdata->page[1].configs);
evry_conf->conf_objects = cfdata->p_object; evry_conf->conf_objects = eina_list_clone(cfdata->page[2].configs);
cfdata->p_subject = NULL; for (i = 0; i < 3; i++)
cfdata->p_action = NULL; {
cfdata->p_object = NULL; if (cfdata->page[i].cur)
{
if (cfdata->page[i].cur->trigger)
eina_stringshare_del(cfdata->page[i].cur->trigger);
if (cfdata->page[i].trigger[i])
cfdata->page[i].cur->trigger = eina_stringshare_add(cfdata->page[i].trigger);
else
cfdata->page[i].cur->trigger = NULL;
cfdata->page[i].cur->trigger_only = cfdata->page[i].trigger_only;
cfdata->page[i].cur->view_mode = cfdata->page[i].view_mode;
}
}
if (evry_conf->cmd_terminal) if (evry_conf->cmd_terminal)
eina_stringshare_del(evry_conf->cmd_terminal); eina_stringshare_del(evry_conf->cmd_terminal);
@ -198,7 +220,7 @@ _plugin_move(Eina_List *plugins, Evas_Object *list, int dir)
Eina_List *l1, *l2; Eina_List *l1, *l2;
sel = e_widget_ilist_selected_get(list); sel = e_widget_ilist_selected_get(list);
if (sel >= 0) if (sel >= 0)
{ {
Plugin_Config *pc; Plugin_Config *pc;
@ -232,85 +254,205 @@ _plugin_move_down_cb(void *data, void *data2)
_plugin_move(data2, data, 1); _plugin_move(data2, data, 1);
} }
static Evas_Object * static void
_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata) _list_select_cb (void *data, Evas_Object *obj)
{ {
Evas_Object *o, *of, *ob, *otb, *otb2; int sel = e_widget_ilist_selected_get(obj);
Plugin_Config *pc;
Plugin_Page *page = data;
if (sel >= 0)
{
pc = eina_list_nth(page->configs, sel);
e_widget_entry_text_set(page->o_trigger, pc->trigger);
e_widget_disabled_set(page->o_trigger, 0);
e_widget_check_checked_set(page->o_trigger_only, pc->trigger_only);
e_widget_disabled_set(page->o_trigger_only, 0);
e_widget_disabled_set(page->o_view_default, 0);
e_widget_disabled_set(page->o_view_detail, 0);
e_widget_disabled_set(page->o_view_list, 0);
e_widget_disabled_set(page->o_view_thumb, 0);
if (pc->view_mode == -1)
e_widget_radio_toggle_set(page->o_view_default, 1);
else if (pc->view_mode == 0)
e_widget_radio_toggle_set(page->o_view_list, 1);
else if (pc->view_mode == 1)
e_widget_radio_toggle_set(page->o_view_detail, 1);
else if (pc->view_mode == 2)
e_widget_radio_toggle_set(page->o_view_thumb, 1);
page->cur = pc;
}
else
{
e_widget_entry_text_set(page->o_trigger, "");
e_widget_disabled_set(page->o_trigger, 1);
e_widget_disabled_set(page->o_trigger_only, 1);
e_widget_disabled_set(page->o_view_default, 1);
e_widget_disabled_set(page->o_view_detail, 1);
e_widget_disabled_set(page->o_view_list, 1);
e_widget_disabled_set(page->o_view_thumb, 1);
page->cur = NULL;
}
}
static void
_plugin_config_cb(void *data, void *data2)
{
}
static Evas_Object *
_create_plugin_page(E_Config_Dialog_Data *cfdata, Evas *e, Plugin_Page *page)
{
Evas_Object *ot, *o, *of, *ob;
E_Radio_Group *rg;
Evas_Object *list;
of = e_widget_framelist_add(e, _("Active Plugins"), 0);
page->list = e_widget_ilist_add(e, 24, 24, NULL);
e_widget_on_change_hook_set(page->list, _list_select_cb, page);
/* e_widget_on_change_hook_set(ol, _avail_list_cb_change, cfdata); */
_fill_list(page->configs, page->list, 0);
e_widget_framelist_object_append(of, page->list);
o = e_widget_button_add(e, _("Move Up"), NULL,
_plugin_move_up_cb,
page->list, page->configs);
e_widget_framelist_object_append(of, o);
o = e_widget_button_add(e, _("Move Down"), NULL,
_plugin_move_down_cb,
page->list, page->configs);
e_widget_framelist_object_append(of, o);
ob = e_widget_table_add(e, 1);
e_widget_table_object_append(ob, of, 0, 0, 1, 3, 1, 1, 1, 1);
of = e_widget_framelist_add(e, _("Plugin Trigger"), 0);
o = e_widget_entry_add(e, &(page->trigger), NULL, NULL, NULL);
e_widget_disabled_set(o, 1);
page->o_trigger = o;
e_widget_framelist_object_append(of, o);
o = e_widget_check_add(e, _("Show only when triggered"),
&(page->trigger_only));
e_widget_disabled_set(o, 1);
page->o_trigger_only = o;
e_widget_framelist_object_append(of, o);
e_widget_table_object_append(ob, of, 1, 0, 1, 1, 1, 1, 1, 1);
of = e_widget_framelist_add(e, _("Plugin View"), 0);
rg = e_widget_radio_group_new(&page->view_mode);
o = e_widget_radio_add(e, _("Default"), -1, rg);
e_widget_disabled_set(o, 1);
page->o_view_default = o;
e_widget_framelist_object_append(of, o);
o = e_widget_radio_add(e, _("List"), 0, rg);
e_widget_framelist_object_append(of, o);
e_widget_disabled_set(o, 1);
page->o_view_list = o;
o = e_widget_radio_add(e, _("Detailed"), 1, rg);
e_widget_disabled_set(o, 1);
page->o_view_detail = o;
e_widget_framelist_object_append(of, o);
o = e_widget_radio_add(e, _("Icons"), 2, rg);
e_widget_disabled_set(o, 1);
page->o_view_thumb = o;
e_widget_framelist_object_append(of, o);
e_widget_table_object_append(ob, of, 1, 1, 1, 1, 1, 1, 1, 1);
/* of = e_widget_framelist_add(e, _("Plugin Cofiguration"), 0);
* o = e_widget_button_add(e, _("Configure"), NULL,
* _plugin_config_cb,
* cfdata->l_subject,
* cfdata->p_subject);
* e_widget_framelist_object_append(of, o); */
/* e_widget_table_object_append(ob, of, 1, 2, 1, 1, 1, 0, 1, 0); */
return ob;
}
static Evas_Object *
_basic_create_widgets(E_Config_Dialog *cfd, Evas *e, E_Config_Dialog_Data *cfdata)
{
Evas_Object *ot, *o, *of, *ob, *otb, *otb2;
E_Radio_Group *rg; E_Radio_Group *rg;
otb = e_widget_toolbook_add(evas, 48 * e_scale, 48 * e_scale); otb = e_widget_toolbook_add(e, 48 * e_scale, 48 * e_scale);
o = e_widget_table_add(evas, 0); o = e_widget_table_add(e, 0);
/// GENERAL SETTNGS /// /// GENERAL SETTNGS ///
of = e_widget_framelist_add(evas, _("General"), 0); of = e_widget_framelist_add(e, _("General"), 0);
ob = e_widget_check_add(evas, _("Hide input when inactive"), ob = e_widget_check_add(e, _("Hide input when inactive"),
&(cfdata->hide_input)); &(cfdata->hide_input));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_check_add(evas, _("Hide list"), ob = e_widget_check_add(e, _("Hide list"),
&(cfdata->hide_list)); &(cfdata->hide_list));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_label_add(evas, _("Quick Navigation")); ob = e_widget_label_add(e, _("Quick Navigation"));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
rg = e_widget_radio_group_new(&cfdata->quick_nav); rg = e_widget_radio_group_new(&cfdata->quick_nav);
ob = e_widget_radio_add(evas, _("Off"), 0, rg); ob = e_widget_radio_add(e, _("Off"), 0, rg);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("Emacs style (ALT + n,p,f,b,m,i)"), 3, rg); ob = e_widget_radio_add(e, _("Emacs style (ALT + n,p,f,b,m,i)"), 3, rg);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("Vi style (ALT + h,j,k,l,n,p,m,i)"), 1, rg); ob = e_widget_radio_add(e, _("Vi style (ALT + h,j,k,l,n,p,m,i)"), 1, rg);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
e_widget_table_object_append(o, of, 0, 0, 1, 1, 0, 0, 0, 0); e_widget_table_object_append(o, of, 0, 0, 1, 1, 0, 0, 0, 0);
of = e_widget_framelist_add(e, _("Default View"), 0);
of = e_widget_framelist_add(evas, _("Default View"), 0);
rg = e_widget_radio_group_new(&cfdata->view_mode); rg = e_widget_radio_group_new(&cfdata->view_mode);
ob = e_widget_radio_add(evas, _("List"), 0, rg); ob = e_widget_radio_add(e, _("List"), 0, rg);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("Detailed"), 1, rg); ob = e_widget_radio_add(e, _("Detailed"), 1, rg);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("Icons"), 2, rg); ob = e_widget_radio_add(e, _("Icons"), 2, rg);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_check_add(evas, _("Animate scrolling"), ob = e_widget_check_add(e, _("Animate scrolling"),
&(cfdata->scroll_animate)); &(cfdata->scroll_animate));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
/* ob = e_widget_slider_add(evas, 1, 0, _("%1.1f"), /* ob = e_widget_slider_add(e, 1, 0, _("%1.1f"),
* 5, 20, 0.1, 0, &(cfdata->scroll_speed), NULL, 10); * 5, 20, 0.1, 0, &(cfdata->scroll_speed), NULL, 10);
* e_widget_framelist_object_append(of, ob); */ * e_widget_framelist_object_append(of, ob); */
ob = e_widget_check_add(evas, _("Up/Down select next item in icon view"), ob = e_widget_check_add(e, _("Up/Down select next item in icon view"),
&(cfdata->cycle_mode)); &(cfdata->cycle_mode));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
e_widget_table_object_append(o, of, 1, 0, 1, 1, 0, 1, 0, 0); e_widget_table_object_append(o, of, 1, 0, 1, 1, 0, 1, 0, 0);
of = e_widget_framelist_add(evas, _("Sorting"), 0); of = e_widget_framelist_add(e, _("Sorting"), 0);
rg = e_widget_radio_group_new(&cfdata->history_sort_mode); rg = e_widget_radio_group_new(&cfdata->history_sort_mode);
ob = e_widget_radio_add(evas, _("By usage"), 0, rg); ob = e_widget_radio_add(e, _("By usage"), 0, rg);
e_widget_radio_toggle_set(ob, (cfdata->history_sort_mode == 0)); e_widget_radio_toggle_set(ob, (cfdata->history_sort_mode == 0));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("Most used"), 1, rg); ob = e_widget_radio_add(e, _("Most used"), 1, rg);
e_widget_radio_toggle_set(ob, (cfdata->history_sort_mode == 1)); e_widget_radio_toggle_set(ob, (cfdata->history_sort_mode == 1));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_radio_add(evas, _("Last used"), 2, rg); ob = e_widget_radio_add(e, _("Last used"), 2, rg);
e_widget_radio_toggle_set(ob, (cfdata->history_sort_mode == 2)); e_widget_radio_toggle_set(ob, (cfdata->history_sort_mode == 2));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
e_widget_table_object_append(o, of, 0, 1, 2, 1, 1, 0, 0, 0); e_widget_table_object_append(o, of, 0, 1, 2, 1, 1, 0, 0, 0);
of = e_widget_framelist_add(evas, _("Commands"), 0); of = e_widget_framelist_add(e, _("Commands"), 0);
ob = e_widget_label_add(evas, _("Terminal Command")); ob = e_widget_label_add(e, _("Terminal Command"));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_entry_add(evas, &(cfdata->cmd_terminal), NULL, NULL, NULL); ob = e_widget_entry_add(e, &(cfdata->cmd_terminal), NULL, NULL, NULL);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_label_add(evas, _("Sudo GUI")); ob = e_widget_label_add(e, _("Sudo GUI"));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_entry_add(evas, &(cfdata->cmd_sudo), NULL, NULL, NULL); ob = e_widget_entry_add(e, &(cfdata->cmd_sudo), NULL, NULL, NULL);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
e_widget_table_object_append(o, of, 0, 2, 2, 1, 1, 0, 0, 0); e_widget_table_object_append(o, of, 0, 2, 2, 1, 1, 0, 0, 0);
@ -319,105 +461,54 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
o, 1, 0, 1, 0, 0.5, 0.0); o, 1, 0, 1, 0, 0.5, 0.0);
/// PLUGINS /// /// PLUGINS ///
otb2 = e_widget_toolbook_add(evas, 48 * e_scale, 48 * e_scale); otb2 = e_widget_toolbook_add(e, 48 * e_scale, 48 * e_scale);
ob = e_widget_list_add(evas, 1, 1); ob = _create_plugin_page(cfdata, e, &cfdata->page[0]);
of = e_widget_framelist_add(evas, _("Active Plugins"), 0);
o = e_widget_ilist_add(evas, 24, 24, NULL);
cfdata->l_subject = o;
/* e_widget_on_change_hook_set(ol, _avail_list_cb_change, cfdata); */
_fill_list(cfdata->p_subject, o, 0);
e_widget_framelist_object_append(of, o);
o = e_widget_button_add(evas, _("Move Up"), NULL,
_plugin_move_up_cb,
cfdata->l_subject,
cfdata->p_subject);
e_widget_framelist_object_append(of, o);
o = e_widget_button_add(evas, _("Move Down"), NULL,
_plugin_move_down_cb,
cfdata->l_subject,
cfdata->p_subject);
e_widget_framelist_object_append(of, o);
e_widget_list_object_append(ob, of, 1, 1, 0.5);
e_widget_toolbook_page_append(otb2, NULL, _("Subject Plugins"), e_widget_toolbook_page_append(otb2, NULL, _("Subject Plugins"),
of, 1, 0, 1, 0, 0.5, 0.0);
ob = e_widget_list_add(evas, 1, 1);
of = e_widget_framelist_add(evas, _("Active Plugins"), 0);
o = e_widget_ilist_add(evas, 24, 24, NULL);
cfdata->l_action = o;
_fill_list(cfdata->p_action, o, 0);
e_widget_framelist_object_append(of, o);
o = e_widget_button_add(evas, _("Move Up"), NULL,
_plugin_move_up_cb,
cfdata->l_action,
cfdata->p_action);
e_widget_framelist_object_append(of, o);
o = e_widget_button_add(evas, _("Move Down"), NULL,
_plugin_move_down_cb,
cfdata->l_action,
cfdata->p_action);
e_widget_framelist_object_append(of, o);
e_widget_list_object_append(ob, of, 1, 1, 0.5);
e_widget_toolbook_page_append(otb2, NULL, _("Action Plugins"),
of, 1, 0, 1, 0, 0.5, 0.0);
ob = e_widget_list_add(evas, 1, 1);
of = e_widget_framelist_add(evas, _("Active Plugins"), 0);
o = e_widget_ilist_add(evas, 24, 24, NULL);
cfdata->l_object = o;
_fill_list(cfdata->p_object, o, 0);
e_widget_framelist_object_append(of, o);
o = e_widget_button_add(evas, _("Move Up"), NULL,
_plugin_move_up_cb,
cfdata->l_object,
cfdata->p_object);
e_widget_framelist_object_append(of, o);
o = e_widget_button_add(evas, _("Move Down"), NULL,
_plugin_move_down_cb,
cfdata->l_object,
cfdata->p_object);
e_widget_framelist_object_append(of, o);
e_widget_list_object_append(ob, of, 1, 1, 0.5);
e_widget_toolbook_page_append(otb2, NULL, _("Object Plugins"),
ob, 1, 0, 1, 0, 0.5, 0.0); ob, 1, 0, 1, 0, 0.5, 0.0);
e_widget_toolbook_page_show(otb2, 0); ob = _create_plugin_page(cfdata, e, &cfdata->page[1]);
e_widget_toolbook_page_append(otb2, NULL, _("Action Plugins"),
ob, 1, 0, 1, 0, 0.5, 0.0);
ob = _create_plugin_page(cfdata, e, &cfdata->page[2]);
e_widget_toolbook_page_append(otb2, NULL, _("Object Plugins"),
ob, 1, 0, 1, 0, 0.5, 0.0);
e_widget_toolbook_page_append(otb, NULL, _("Plugins"), e_widget_toolbook_page_append(otb, NULL, _("Plugins"),
otb2, 1, 0, 1, 0, 0.5, 0.0); otb2, 1, 0, 1, 0, 0.5, 0.0);
e_widget_toolbook_page_show(otb2, 0);
/// GEOMERY /// /// GEOMERY ///
o = e_widget_list_add(evas, 0, 0); o = e_widget_list_add(e, 0, 0);
of = e_widget_framelist_add(evas, _("Popup Size"), 0); of = e_widget_framelist_add(e, _("Popup Size"), 0);
ob = e_widget_label_add(evas, _("Popup Width")); ob = e_widget_label_add(e, _("Popup Width"));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_slider_add(evas, 1, 0, _("%1.0f"), ob = e_widget_slider_add(e, 1, 0, _("%1.0f"),
evry_conf->min_w, 800, 5, 0, NULL, evry_conf->min_w, 800, 5, 0, NULL,
&(cfdata->width), 200); &(cfdata->width), 200);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_label_add(evas, _("Popup Height")); ob = e_widget_label_add(e, _("Popup Height"));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_slider_add(evas, 1, 0, _("%1.0f"), ob = e_widget_slider_add(e, 1, 0, _("%1.0f"),
evry_conf->min_h, 800, 5, 0, NULL, evry_conf->min_h, 800, 5, 0, NULL,
&(cfdata->height), 200); &(cfdata->height), 200);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
e_widget_list_object_append(o, of, 1, 1, 0.5); e_widget_list_object_append(o, of, 1, 1, 0.5);
of = e_widget_framelist_add(evas, _("Popup Align"), 0); of = e_widget_framelist_add(e, _("Popup Align"), 0);
ob = e_widget_label_add(evas, _("Vertical")); ob = e_widget_label_add(e, _("Vertical"));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_slider_add(evas, 1, 0, _("%1.2f"), ob = e_widget_slider_add(e, 1, 0, _("%1.2f"),
0.0, 1.0, 0.01, 0, 0.0, 1.0, 0.01, 0,
&(cfdata->rel_y), NULL, 200); &(cfdata->rel_y), NULL, 200);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_label_add(evas, _("Horizontal")); ob = e_widget_label_add(e, _("Horizontal"));
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);
ob = e_widget_slider_add(evas, 1, 0, _("%1.2f"), ob = e_widget_slider_add(e, 1, 0, _("%1.2f"),
0.0, 1.0, 0.01, 0, 0.0, 1.0, 0.01, 0,
&(cfdata->rel_x), NULL, 200); &(cfdata->rel_x), NULL, 200);
e_widget_framelist_object_append(of, ob); e_widget_framelist_object_append(of, ob);

View File

@ -323,6 +323,7 @@ evry_plug_aggregator_new(Evry_Selector *selector)
pc = E_NEW(Plugin_Config, 1); pc = E_NEW(Plugin_Config, 1);
pc->enabled = 1; pc->enabled = 1;
pc->priority = -1; pc->priority = -1;
pc->view_mode = -1;
EVRY_PLUGIN(p)->config = pc; EVRY_PLUGIN(p)->config = pc;
p->selector = selector; p->selector = selector;

View File

@ -963,11 +963,21 @@ _view_update(Evry_View *view, int slide)
} }
if (p != v->plugin) if (p != v->plugin)
{ {
v->mode = v->mode_prev; if (p->config->view_mode >= 0)
{
if (p->view_mode >= 0) if (p->config->view_mode != v->mode)
v->mode = p->view_mode; _clear_items(v->span);
v->mode = p->config->view_mode;
}
else
{
if (v->mode_prev != v->mode)
_clear_items(v->span);
v->mode = v->mode_prev;
}
} }
/* go through current view items */ /* go through current view items */
@ -1328,6 +1338,7 @@ _view_create(Evry_View *view, const Evry_State *s, const Evas_Object *swallow)
v->mode = evry_conf->view_mode; v->mode = evry_conf->view_mode;
else else
v->mode = parent->mode; v->mode = parent->mode;
v->mode_prev = v->mode; v->mode_prev = v->mode;
v->zoom = parent->zoom; v->zoom = parent->zoom;