Make Icon Theme Dialog play nice on small screens.
Fix some formatting. SVN revision: 50544
This commit is contained in:
parent
9e0d1a8180
commit
84bac7309c
|
@ -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,7 +18,8 @@ struct _E_Config_Dialog_Data
|
|||
const char *themename;
|
||||
int overrides;
|
||||
int populating;
|
||||
struct {
|
||||
struct
|
||||
{
|
||||
Evas_Object *list;
|
||||
Evas_Object *checkbox;
|
||||
Evas_Object *preview[4]; /* same size as _icon_previews */
|
||||
|
@ -27,7 +27,8 @@ struct _E_Config_Dialog_Data
|
|||
Ecore_Idler *fill_icon_themes_delayed;
|
||||
};
|
||||
|
||||
static const char *_icon_previews[4] = {
|
||||
static const char *_icon_previews[4] =
|
||||
{
|
||||
"system-run",
|
||||
"system-file-manager",
|
||||
"preferences-desktop-theme",
|
||||
|
@ -47,12 +48,11 @@ 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"),
|
||||
cfd = e_config_dialog_new(con, _("Icon Theme Settings"),
|
||||
"E", "appearance/icon_theme",
|
||||
"preferences-icon-theme", 0, v, NULL);
|
||||
return cfd;
|
||||
|
@ -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,7 +161,8 @@ _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[] = {
|
||||
const char **example_icon, *example_icons[] =
|
||||
{
|
||||
NULL,
|
||||
"folder",
|
||||
"user-home",
|
||||
|
@ -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;
|
||||
}
|
||||
|
||||
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);
|
||||
|
|
Loading…
Reference in New Issue