fix theme selector to also scamn system and user themes... AND fix some bugs
too! SVN revision: 21702
This commit is contained in:
parent
b9f31348f7
commit
500a7e479e
|
@ -123,12 +123,15 @@ static Evas_Object *
|
||||||
_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
|
_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
|
||||||
{
|
{
|
||||||
/* generate the core widget layout for a basic dialog */
|
/* generate the core widget layout for a basic dialog */
|
||||||
Evas_Object *o, *fr, *im = NULL;
|
Evas_Object *o, *o2, *fr, *im = NULL;
|
||||||
Evas_Object *il;
|
Evas_Object *il;
|
||||||
char buf[4096];
|
char buf[4096];
|
||||||
char *homedir;
|
char *homedir;
|
||||||
Evas_Object *theme;
|
Evas_Object *theme;
|
||||||
char fulltheme[PATH_MAX];
|
char fulltheme[PATH_MAX];
|
||||||
|
int i = 0, j, selnum = -1;
|
||||||
|
Ecore_Evas *eebuf;
|
||||||
|
Evas *evasbuf;
|
||||||
|
|
||||||
theme = edje_object_add(evas);
|
theme = edje_object_add(evas);
|
||||||
|
|
||||||
|
@ -138,54 +141,61 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
|
||||||
o = e_widget_table_add(evas, 0);
|
o = e_widget_table_add(evas, 0);
|
||||||
|
|
||||||
il = e_widget_ilist_add(evas, 48, 48, &(cfdata->theme));
|
il = e_widget_ilist_add(evas, 48, 48, &(cfdata->theme));
|
||||||
|
|
||||||
|
eebuf = ecore_evas_buffer_new(1, 1);
|
||||||
|
evasbuf = ecore_evas_get(eebuf);
|
||||||
|
o2 = edje_object_add(evasbuf);
|
||||||
|
|
||||||
|
for (j = 0; j < 2; j++)
|
||||||
|
{
|
||||||
|
Ecore_List *themes;
|
||||||
|
char *themefile;
|
||||||
|
|
||||||
|
if (j == 0)
|
||||||
|
{
|
||||||
homedir = e_user_homedir_get();
|
homedir = e_user_homedir_get();
|
||||||
if (homedir)
|
if (homedir)
|
||||||
{
|
{
|
||||||
snprintf(buf, sizeof(buf), "%s/.e/e/themes", homedir);
|
snprintf(buf, sizeof(buf), "%s/.e/e/themes", homedir);
|
||||||
free(homedir);
|
free(homedir);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (ecore_file_is_dir(buf))
|
else if (j == 1)
|
||||||
{
|
{
|
||||||
Ecore_List *themes;
|
snprintf(buf, sizeof(buf), "%s/data/themes", e_prefix_data_get());
|
||||||
|
}
|
||||||
|
if (!ecore_file_is_dir(buf)) continue;
|
||||||
themes = ecore_file_ls(buf);
|
themes = ecore_file_ls(buf);
|
||||||
if (themes)
|
if (!themes) continue;
|
||||||
|
if (j == 0)
|
||||||
{
|
{
|
||||||
/* add default theme */
|
e_widget_ilist_header_append(il, NULL, _("Personal"));
|
||||||
ecore_list_prepend(themes, strdup("default.edj"));
|
i++;
|
||||||
ecore_list_goto_first(themes);
|
}
|
||||||
|
else if (j == 1)
|
||||||
Evas_Object *o;
|
{
|
||||||
Ecore_Evas *eebuf;
|
e_widget_ilist_header_append(il, NULL, _("System"));
|
||||||
Evas *evasbuf;
|
i++;
|
||||||
int i = 0;
|
}
|
||||||
char *themefile;
|
|
||||||
|
|
||||||
eebuf = ecore_evas_buffer_new(1, 1);
|
|
||||||
evasbuf = ecore_evas_get(eebuf);
|
|
||||||
o = edje_object_add(evasbuf);
|
|
||||||
|
|
||||||
while ((themefile = ecore_list_next(themes)))
|
while ((themefile = ecore_list_next(themes)))
|
||||||
{
|
{
|
||||||
if (!strcmp(themefile, "default.edj"))
|
printf("%s\n", themefile);
|
||||||
snprintf(fulltheme, sizeof(fulltheme), PACKAGE_DATA_DIR"/data/themes/default.edj");
|
|
||||||
else
|
|
||||||
snprintf(fulltheme, sizeof(fulltheme), "%s/%s", buf, themefile);
|
snprintf(fulltheme, sizeof(fulltheme), "%s/%s", buf, themefile);
|
||||||
if (ecore_file_is_dir(fulltheme))
|
if (ecore_file_is_dir(fulltheme)) continue;
|
||||||
continue;
|
|
||||||
|
|
||||||
|
printf("%s\n", fulltheme);
|
||||||
/* minimum theme requirements */
|
/* minimum theme requirements */
|
||||||
if (edje_object_file_set(o, fulltheme, "desktop/background"))
|
if (edje_object_file_set(o2, fulltheme, "desktop/background"))
|
||||||
{
|
{
|
||||||
Evas_Object *o = NULL;
|
Evas_Object *o3 = NULL;
|
||||||
char *noext;
|
char *noext;
|
||||||
E_Cfg_Theme_Data *cb_data;
|
E_Cfg_Theme_Data *cb_data;
|
||||||
|
|
||||||
if (!e_thumb_exists(fulltheme))
|
if (!e_thumb_exists(fulltheme))
|
||||||
o = e_thumb_generate_begin(fulltheme, 48, 48, cfd->dia->win->evas, &o, NULL, NULL);
|
o3 = e_thumb_generate_begin(fulltheme, 48, 48, cfd->dia->win->evas, &o, NULL, NULL);
|
||||||
else
|
else
|
||||||
o = e_thumb_evas_object_get(fulltheme, cfd->dia->win->evas, 48, 48, 1);
|
o3 = e_thumb_evas_object_get(fulltheme, cfd->dia->win->evas, 48, 48, 1);
|
||||||
|
|
||||||
noext = ecore_file_strip_ext(themefile);
|
noext = ecore_file_strip_ext(themefile);
|
||||||
|
|
||||||
|
@ -194,25 +204,27 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
|
||||||
cb_data->file = strdup(fulltheme);
|
cb_data->file = strdup(fulltheme);
|
||||||
cb_data->theme = strdup(themefile);
|
cb_data->theme = strdup(themefile);
|
||||||
|
|
||||||
e_widget_ilist_append(il, o, noext, _e_config_theme_cb_standard, cb_data, themefile);
|
printf("append %s %p\n", noext, o3);
|
||||||
|
e_widget_ilist_append(il, o3, noext,
|
||||||
|
_e_config_theme_cb_standard, cb_data,
|
||||||
|
themefile);
|
||||||
if (!(strcmp(themefile, cfdata->current_theme)))
|
if (!(strcmp(themefile, cfdata->current_theme)))
|
||||||
{
|
{
|
||||||
e_widget_ilist_selected_set(il, i);
|
selnum = i;
|
||||||
im = e_widget_preview_add(evas, 320, 240);
|
im = e_widget_preview_add(evas, 320, 240);
|
||||||
e_widget_preview_edje_set(im, fulltheme, "desktop/background");
|
e_widget_preview_edje_set(im, fulltheme, "desktop/background");
|
||||||
// im = e_widget_image_add_from_object(evas, theme, 320, 240);
|
// im = e_widget_image_add_from_object(evas, theme, 320, 240);
|
||||||
// e_widget_image_object_set(im, e_thumb_evas_object_get(fulltheme, evas, 320, 240, 1));
|
// e_widget_image_object_set(im, e_thumb_evas_object_get(fulltheme, evas, 320, 240, 1));
|
||||||
}
|
}
|
||||||
free(noext);
|
free(noext);
|
||||||
i++;
|
i++;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
free(themefile);
|
free(themefile);
|
||||||
evas_object_del(o);
|
|
||||||
ecore_evas_free(eebuf);
|
|
||||||
ecore_list_destroy(themes);
|
ecore_list_destroy(themes);
|
||||||
}
|
}
|
||||||
}
|
evas_object_del(o2);
|
||||||
|
ecore_evas_free(eebuf);
|
||||||
|
|
||||||
e_widget_ilist_go(il);
|
e_widget_ilist_go(il);
|
||||||
e_widget_min_size_set(il, 180, 40);
|
e_widget_min_size_set(il, 180, 40);
|
||||||
|
@ -230,6 +242,8 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
|
||||||
|
|
||||||
e_widget_table_object_append(o, im, 1, 0, 1, 2, 1, 1, 1, 1);
|
e_widget_table_object_append(o, im, 1, 0, 1, 2, 1, 1, 1, 1);
|
||||||
|
|
||||||
|
if (selnum >= 0) e_widget_ilist_selected_set(il, selnum);
|
||||||
|
|
||||||
return o;
|
return o;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue