forked from enlightenment/enlightenment
NOW we can add/del shelves... still not done.
SVN revision: 22414
This commit is contained in:
parent
2bc5d52739
commit
362b6bb159
|
@ -4,7 +4,6 @@
|
|||
#include "e.h"
|
||||
|
||||
/* PROTOTYPES - same all the time */
|
||||
typedef struct _CFBorder CFBorder;
|
||||
|
||||
static void *_create_data(E_Config_Dialog *cfd);
|
||||
static void _free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
|
||||
|
@ -17,13 +16,6 @@ struct _E_Config_Dialog_Data
|
|||
E_Border *border;
|
||||
char *bordername;
|
||||
int remember_border;
|
||||
Evas_List *cfblist;
|
||||
};
|
||||
|
||||
struct _CFBorder
|
||||
{
|
||||
E_Config_Dialog_Data *cfdata;
|
||||
const char *bordername;
|
||||
};
|
||||
|
||||
/* a nice easy setup function that does the dirty work */
|
||||
|
@ -81,11 +73,6 @@ _free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
|
|||
/* Free the cfdata */
|
||||
cfdata->border->border_border_dialog = NULL;
|
||||
E_FREE(cfdata->bordername);
|
||||
while (cfdata->cfblist)
|
||||
{
|
||||
E_FREE(cfdata->cfblist->data);
|
||||
cfdata->cfblist = evas_list_remove_list(cfdata->cfblist, cfdata->cfblist);
|
||||
}
|
||||
free(cfdata);
|
||||
}
|
||||
|
||||
|
@ -146,7 +133,6 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
|
|||
Evas_Coord wmw, wmh;
|
||||
Evas_List *borders, *l;
|
||||
int sel, n;
|
||||
CFBorder *cfb;
|
||||
|
||||
o = e_widget_list_add(evas, 0, 0);
|
||||
|
||||
|
@ -155,10 +141,6 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
|
|||
sel = 0;
|
||||
borders = e_theme_border_list();
|
||||
|
||||
cfb = E_NEW(CFBorder, 1);
|
||||
cfb->cfdata = cfdata;
|
||||
cfb->bordername = "borderless";
|
||||
cfdata->cfblist = evas_list_append(cfdata->cfblist, cfb);
|
||||
orect = evas_object_rectangle_add(evas);
|
||||
evas_object_color_set(orect, 0, 0, 0, 128);
|
||||
e_widget_ilist_append(oi, orect, "borderless", NULL, NULL, "borderless");
|
||||
|
@ -167,15 +149,10 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
|
|||
{
|
||||
char buf[4096];
|
||||
|
||||
cfb = E_NEW(CFBorder, 1);
|
||||
cfb->cfdata = cfdata;
|
||||
cfb->bordername = l->data;
|
||||
cfdata->cfblist = evas_list_append(cfdata->cfblist, cfb);
|
||||
ob = e_livethumb_add(evas);
|
||||
e_livethumb_vsize_set(ob, 160, 96);
|
||||
oj = edje_object_add(e_livethumb_evas_get(ob));
|
||||
snprintf(buf, sizeof(buf), "widgets/border/%s/border",
|
||||
(char *)l->data);
|
||||
snprintf(buf, sizeof(buf), "widgets/border/%s/border", (char *)l->data);
|
||||
e_theme_edje_object_set(oj, "base/theme/borders", buf);
|
||||
e_livethumb_thumb_set(ob, oj);
|
||||
orect = evas_object_rectangle_add(e_livethumb_evas_get(ob));
|
||||
|
|
|
@ -7,7 +7,8 @@ static Evas_Object *_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Co
|
|||
|
||||
struct _E_Config_Dialog_Data
|
||||
{
|
||||
int dummy;
|
||||
E_Config_Dialog *cfd;
|
||||
Evas_Object *ilist;
|
||||
};
|
||||
|
||||
EAPI E_Config_Dialog *
|
||||
|
@ -40,6 +41,7 @@ _create_data(E_Config_Dialog *cfd)
|
|||
E_Config_Dialog_Data *cfdata;
|
||||
|
||||
cfdata = E_NEW(E_Config_Dialog_Data, 1);
|
||||
cfdata->cfd = cfd;
|
||||
_fill_data(cfdata);
|
||||
return cfdata;
|
||||
}
|
||||
|
@ -56,11 +58,148 @@ _basic_apply_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
|
|||
return 1;
|
||||
}
|
||||
|
||||
static void
|
||||
_cb_list(void *data)
|
||||
{
|
||||
E_Config_Dialog_Data *cfdata;
|
||||
|
||||
cfdata = data;
|
||||
}
|
||||
|
||||
static void
|
||||
_ilist_fill(E_Config_Dialog_Data *cfdata)
|
||||
{
|
||||
Evas_List *l;
|
||||
E_Shelf *es;
|
||||
char buf[256];
|
||||
const char *label;
|
||||
Evas_Object *ob;
|
||||
int n;
|
||||
Evas_Coord wmw, wmh;
|
||||
|
||||
n = e_widget_ilist_selected_get(cfdata->ilist);
|
||||
e_widget_ilist_clear(cfdata->ilist);
|
||||
for (l = e_shelf_list(); l; l = l->next)
|
||||
{
|
||||
es = l->data;
|
||||
|
||||
label = es->name;
|
||||
if (!label) label = "";
|
||||
snprintf(buf, sizeof(buf), "%s #%i", label, es->id);
|
||||
|
||||
/* FIXME: proper icon */
|
||||
ob = edje_object_add(evas_object_evas_get(cfdata->ilist));
|
||||
e_util_edje_icon_set(ob, "enlightenment/e");
|
||||
|
||||
e_widget_ilist_append(cfdata->ilist, ob, buf, _cb_list, cfdata, NULL);
|
||||
}
|
||||
e_widget_min_size_get(cfdata->ilist, &wmw, &wmh);
|
||||
e_widget_min_size_set(cfdata->ilist, wmw, 250);
|
||||
e_widget_ilist_go(cfdata->ilist);
|
||||
e_widget_ilist_selected_set(cfdata->ilist, n);
|
||||
}
|
||||
|
||||
static void
|
||||
_cb_add(void *data, void *data2)
|
||||
{
|
||||
E_Config_Dialog_Data *cfdata;
|
||||
Evas_List *shelves;
|
||||
|
||||
cfdata = data;
|
||||
while ((shelves = e_shelf_list()))
|
||||
{
|
||||
E_Shelf *es;
|
||||
|
||||
es = shelves->data;
|
||||
e_object_del(E_OBJECT(es));
|
||||
}
|
||||
////
|
||||
{
|
||||
E_Config_Shelf *cfg;
|
||||
E_Shelf *es;
|
||||
|
||||
cfg = E_NEW(E_Config_Shelf, 1);
|
||||
cfg->name = evas_stringshare_add("shelf");
|
||||
cfg->container = cfdata->cfd->con->num;
|
||||
cfg->zone = cfdata->cfd->dia->win->border->zone->num;
|
||||
cfg->popup = 1;
|
||||
cfg->layer = 200;
|
||||
cfg->orient = E_GADCON_ORIENT_CORNER_BR;
|
||||
cfg->fit_along = 1;
|
||||
cfg->fit_size = 0;
|
||||
cfg->style = evas_stringshare_add("default");
|
||||
cfg->size = 40;
|
||||
e_config->shelves = evas_list_append(e_config->shelves, cfg);
|
||||
}
|
||||
e_shelf_config_init();
|
||||
e_config_save_queue();
|
||||
|
||||
_ilist_fill(cfdata);
|
||||
}
|
||||
|
||||
static void
|
||||
_cb_del(void *data, void *data2)
|
||||
{
|
||||
E_Config_Dialog_Data *cfdata;
|
||||
E_Shelf *es;
|
||||
E_Config_Shelf *cfg;
|
||||
|
||||
cfdata = data;
|
||||
es = evas_list_nth(e_shelf_list(), e_widget_ilist_selected_get(cfdata->ilist));
|
||||
if (!es) return;
|
||||
cfg = es->cfg;
|
||||
e_object_del(E_OBJECT(es));
|
||||
|
||||
e_config->shelves = evas_list_remove(e_config->shelves, cfg);
|
||||
if (cfg->name) evas_stringshare_del(cfg->name);
|
||||
if (cfg->style) evas_stringshare_del(cfg->style);
|
||||
E_FREE(cfg);
|
||||
|
||||
e_config_save_queue();
|
||||
|
||||
_ilist_fill(cfdata);
|
||||
}
|
||||
|
||||
static void
|
||||
_cb_config(void *data, void *data2)
|
||||
{
|
||||
E_Config_Dialog_Data *cfdata;
|
||||
E_Shelf *es;
|
||||
|
||||
cfdata = data;
|
||||
es = evas_list_nth(e_shelf_list(), e_widget_ilist_selected_get(cfdata->ilist));
|
||||
if (!es) return;
|
||||
e_int_shelf_config(es);
|
||||
}
|
||||
|
||||
static Evas_Object *
|
||||
_basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cfdata)
|
||||
{
|
||||
Evas_Object *o;
|
||||
Evas_Object *o, *of, *oi, *ob, *ol;
|
||||
|
||||
o = e_widget_list_add(evas, 0, 0);
|
||||
o = e_widget_list_add(evas, 0, 1);
|
||||
|
||||
of = e_widget_framelist_add(evas, _("Configured Shelves"), 0);
|
||||
oi = e_widget_ilist_add(evas, 80, 60, NULL);
|
||||
e_widget_ilist_selector_set(oi, 1);
|
||||
cfdata->ilist = oi;
|
||||
|
||||
_ilist_fill(cfdata);
|
||||
|
||||
e_widget_framelist_object_append(of, oi);
|
||||
e_widget_list_object_append(o, of, 1, 1, 0.5);
|
||||
|
||||
ol = e_widget_table_add(evas, 0);
|
||||
|
||||
ob = e_widget_button_add(evas, _("Add"), "widget/add", _cb_add, cfdata, NULL);
|
||||
e_widget_table_object_append(ol, ob, 0, 0, 1, 1, 1, 1, 1, 0);
|
||||
ob = e_widget_button_add(evas, _("Delete"), "widget/del", _cb_del, cfdata, NULL);
|
||||
e_widget_table_object_append(ol, ob, 0, 1, 1, 1, 1, 1, 1, 0);
|
||||
ob = e_widget_button_add(evas, _("Configure..."), "widget/config", _cb_config, cfdata, NULL);
|
||||
e_widget_table_object_append(ol, ob, 0, 2, 1, 1, 1, 1, 1, 0);
|
||||
|
||||
e_widget_list_object_append(o, ol, 1, 1, 0.0);
|
||||
|
||||
|
||||
return o;
|
||||
}
|
||||
|
|
|
@ -4,8 +4,6 @@
|
|||
#include "e.h"
|
||||
|
||||
/* PROTOTYPES - same all the time */
|
||||
typedef struct _CFStyle CFStyle;
|
||||
|
||||
static void *_create_data(E_Config_Dialog *cfd);
|
||||
static void _free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
|
||||
static int _basic_apply_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata);
|
||||
|
@ -22,13 +20,6 @@ struct _E_Config_Dialog_Data
|
|||
int fit_size;
|
||||
int size;
|
||||
int layering;
|
||||
Evas_List *cfslist;
|
||||
};
|
||||
|
||||
struct _CFStyle
|
||||
{
|
||||
E_Config_Dialog_Data *cfdata;
|
||||
const char *style;
|
||||
};
|
||||
|
||||
/* a nice easy setup function that does the dirty work */
|
||||
|
@ -102,11 +93,6 @@ _free_data(E_Config_Dialog *cfd, E_Config_Dialog_Data *cfdata)
|
|||
/* Free the cfdata */
|
||||
cfdata->es->config_dialog = NULL;
|
||||
if (cfdata->style) free(cfdata->style);
|
||||
while (cfdata->cfslist)
|
||||
{
|
||||
E_FREE(cfdata->cfslist->data);
|
||||
cfdata->cfslist = evas_list_remove_list(cfdata->cfslist, cfdata->cfslist);
|
||||
}
|
||||
free(cfdata);
|
||||
}
|
||||
|
||||
|
@ -169,7 +155,6 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
|
|||
Evas_Coord wmw, wmh;
|
||||
Evas_List *styles, *l;
|
||||
int sel, n;
|
||||
CFStyle *cfs;
|
||||
|
||||
/* FIXME: this is just raw config now - it needs UI improvments */
|
||||
o = e_widget_list_add(evas, 0, 1);
|
||||
|
@ -236,15 +221,10 @@ _basic_create_widgets(E_Config_Dialog *cfd, Evas *evas, E_Config_Dialog_Data *cf
|
|||
{
|
||||
char buf[4096];
|
||||
|
||||
cfs = E_NEW(CFStyle, 1);
|
||||
cfs->cfdata = cfdata;
|
||||
cfs->style = "default";
|
||||
cfdata->cfslist = evas_list_append(cfdata->cfslist, cfs);
|
||||
ob = e_livethumb_add(evas);
|
||||
e_livethumb_vsize_set(ob, 256, 40);
|
||||
oj = edje_object_add(e_livethumb_evas_get(ob));
|
||||
snprintf(buf, sizeof(buf), "shelf/%s/base",
|
||||
(char *)l->data);
|
||||
snprintf(buf, sizeof(buf), "shelf/%s/base", (char *)l->data);
|
||||
e_theme_edje_object_set(oj, "base/theme/shelf", buf);
|
||||
e_livethumb_thumb_set(ob, oj);
|
||||
e_widget_ilist_append(oi, ob, (char *)l->data, NULL, NULL, l->data);
|
||||
|
|
|
@ -128,7 +128,7 @@ e_shelf_zone_new(E_Zone *zone, const char *name, const char *style, int popup, i
|
|||
}
|
||||
if (id < 0)
|
||||
{
|
||||
es->id = shelf_id;
|
||||
es->id = evas_list_count(shelves);
|
||||
shelf_id++;
|
||||
}
|
||||
else
|
||||
|
|
Loading…
Reference in New Issue