Make Icon Theme Dialog play nice on small screens.

Fix some formatting.



SVN revision: 50544
This commit is contained in:
Christopher Michael 2010-07-27 15:12:40 +00:00
parent 9e0d1a8180
commit 84bac7309c
1 changed files with 57 additions and 50 deletions

View File

@ -6,9 +6,8 @@
static void *_create_data(E_Config_Dialog *cfd);
static void _free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
static int _basic_check_changed(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 int _basic_apply(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
static Evas_Object *_basic_create(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata);
static int _sort_icon_themes(const void *data1, const void *data2);
static Evas_Object *_icon_new(Evas *evas, const char *theme, const char *icon, unsigned int size);
@ -19,19 +18,21 @@ struct _E_Config_Dialog_Data
const char *themename;
int overrides;
int populating;
struct {
Evas_Object *list;
Evas_Object *checkbox;
Evas_Object *preview[4]; /* same size as _icon_previews */
} gui;
struct
{
Evas_Object *list;
Evas_Object *checkbox;
Evas_Object *preview[4]; /* same size as _icon_previews */
} gui;
Ecore_Idler *fill_icon_themes_delayed;
};
static const char *_icon_previews[4] = {
"system-run",
"system-file-manager",
"preferences-desktop-theme",
"text-x-generic"
static const char *_icon_previews[4] =
{
"system-run",
"system-file-manager",
"preferences-desktop-theme",
"text-x-generic"
};
#define PREVIEW_SIZE (48)
@ -47,13 +48,12 @@ e_int_config_icon_themes(E_Container *con, const char *params __UNUSED__)
v->create_cfdata = _create_data;
v->free_cfdata = _free_data;
v->basic.create_widgets = _basic_create_widgets;
v->basic.apply_cfdata = _basic_apply_data;
v->basic.create_widgets = _basic_create;
v->basic.apply_cfdata = _basic_apply;
v->basic.check_changed = _basic_check_changed;
cfd = e_config_dialog_new(con,
_("Icon Theme Settings"),
"E", "appearance/icon_theme",
cfd = e_config_dialog_new(con, _("Icon Theme Settings"),
"E", "appearance/icon_theme",
"preferences-icon-theme", 0, v, NULL);
return cfd;
}
@ -62,9 +62,9 @@ static void
_fill_data(E_Config_Dialog_Data *cfdata)
{
cfdata->icon_themes = efreet_icon_theme_list_get();
cfdata->icon_themes = eina_list_sort(cfdata->icon_themes,
eina_list_count(cfdata->icon_themes),
_sort_icon_themes);
cfdata->icon_themes = eina_list_sort(cfdata->icon_themes,
eina_list_count(cfdata->icon_themes),
_sort_icon_themes);
return;
}
@ -77,9 +77,7 @@ _create_data(E_Config_Dialog *cfd)
cfdata = E_NEW(E_Config_Dialog_Data, 1);
cfdata->cfd = cfd;
cfdata->themename = eina_stringshare_add(e_config->icon_theme);
cfdata->overrides = e_config->icon_theme_overrides;
return cfdata;
}
@ -110,18 +108,15 @@ _basic_check_changed(E_Config_Dialog *cfd __UNUSED__, E_Config_Dialog_Data *cfda
}
static int
_basic_apply_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
_basic_apply(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
{
E_Event_Config_Icon_Theme *ev;
if (!_basic_check_changed(cfd, cfdata))
return 1;
if (!_basic_check_changed(cfd, cfdata)) return 1;
eina_stringshare_del(e_config->icon_theme);
e_config->icon_theme = eina_stringshare_ref(cfdata->themename);
e_config->icon_theme_overrides = !!cfdata->overrides;
e_config_save_queue();
ev = E_NEW(E_Event_Config_Icon_Theme, 1);
@ -138,9 +133,13 @@ _populate_preview(E_Config_Dialog_Data *cfdata)
{
const char *t = cfdata->themename;
unsigned int i;
for (i = 0; i < sizeof(_icon_previews)/sizeof(_icon_previews[0]); i++)
{
char *path = efreet_icon_path_find(t, _icon_previews[i], PREVIEW_SIZE);
char *path;
if (!(path = efreet_icon_path_find(t, _icon_previews[i], PREVIEW_SIZE)))
continue;
if (e_icon_file_set(cfdata->gui.preview[i], path))
e_icon_fill_inside_set(cfdata->gui.preview[i], EINA_TRUE);
free(path);
@ -162,15 +161,16 @@ _fill_icon_themes(void *data)
struct _fill_icon_themes_data *d = data;
Efreet_Icon_Theme *theme;
Evas_Object *oc = NULL;
const char **example_icon, *example_icons[] = {
NULL,
"folder",
"user-home",
"text-x-generic",
"system-run",
"preferences-system",
NULL,
};
const char **example_icon, *example_icons[] =
{
NULL,
"folder",
"user-home",
"text-x-generic",
"system-run",
"preferences-system",
NULL,
};
if (!d->themes_loaded)
{
@ -184,7 +184,13 @@ _fill_icon_themes(void *data)
if (!d->l)
{
int mw, mh;
e_widget_ilist_go(d->cfdata->gui.list);
e_widget_size_min_get(d->cfdata->gui.list, &mw, &mh);
e_widget_size_min_set(d->cfdata->gui.list, mw, 50);
d->cfdata->fill_icon_themes_delayed = NULL;
d->cfdata->populating = EINA_FALSE;
_populate_preview(d->cfdata);
@ -199,9 +205,7 @@ _fill_icon_themes(void *data)
example_icon = example_icons;
}
else
{
example_icon = example_icons + 1;
}
example_icon = example_icons + 1;
for (; (*example_icon) && (!oc); example_icon++)
oc = _icon_new(d->evas, theme->name.internal, *example_icon, 24);
@ -223,13 +227,15 @@ _fill_icon_themes(void *data)
static void
_icon_theme_changed(void *data, Evas_Object *o __UNUSED__)
{
E_Config_Dialog_Data *cfdata = data;
E_Config_Dialog_Data *cfdata;
cfdata = data;
if (cfdata->populating) return;
_populate_preview(cfdata);
}
static Evas_Object *
_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
_basic_create(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
{
Evas_Object *o, *ilist, *checkbox, *ol;
struct _fill_icon_themes_data *d;
@ -240,7 +246,6 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
ilist = e_widget_ilist_add(evas, 24, 24, &(cfdata->themename));
cfdata->gui.list = ilist;
e_widget_size_min_set(ilist, 200, 240);
cfdata->populating = EINA_TRUE;
e_widget_on_change_hook_set(ilist, _icon_theme_changed, cfdata);
e_widget_list_object_append(o, ilist, 1, 1, 0.5);
@ -251,13 +256,15 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
cfdata->gui.preview[i] = e_icon_add(evas);
e_icon_preload_set(cfdata->gui.preview[i], EINA_TRUE);
e_icon_scale_size_set(cfdata->gui.preview[i], PREVIEW_SIZE);
e_widget_framelist_object_append_full
(ol, cfdata->gui.preview[i], 0, 0, 0, 0, 0.5, 0.5,
PREVIEW_SIZE, PREVIEW_SIZE, PREVIEW_SIZE, PREVIEW_SIZE);
e_widget_framelist_object_append_full(ol, cfdata->gui.preview[i],
0, 0, 0, 0, 0.5, 0.5,
PREVIEW_SIZE, PREVIEW_SIZE,
PREVIEW_SIZE, PREVIEW_SIZE);
}
e_widget_list_object_append(o, ol, 0, 0, 0.5);
checkbox = e_widget_check_add(evas, _("This overrides general theme"), &(cfdata->overrides));
checkbox = e_widget_check_add(evas, _("This overrides general theme"),
&(cfdata->overrides));
e_widget_size_min_get(checkbox, &mw, &mh);
e_widget_list_object_append(o, checkbox, 0, 0, 0.0);
@ -296,9 +303,9 @@ static Evas_Object *
_icon_new(Evas *evas, const char *theme, const char *icon, unsigned int size)
{
Evas_Object *o;
char *path = efreet_icon_path_find(theme, icon, size);
if (!path) return NULL;
char *path;
if (!(path = efreet_icon_path_find(theme, icon, size))) return NULL;
o = e_icon_add(evas);
if (e_icon_file_set(o, path))
e_icon_fill_inside_set(o, 1);