This is an automated email from the git hooks/post-receive script.
git pushed a commit to branch v-0.25.0
in repository enlightenment.
View the commit online.
commit fdb2ca44c3a5e4e5b10237237916485084e90884
Author: Alastair Poole <[email protected]>
AuthorDate: Tue Mar 8 10:51:21 2022 +0000
procstats: fix popup state on maximize/unmaximize
---
src/modules/procstats/e_mod_main.c | 129 +++++++++++++++++++++++++------------
1 file changed, 88 insertions(+), 41 deletions(-)
diff --git a/src/modules/procstats/e_mod_main.c b/src/modules/procstats/e_mod_main.c
index 41bff03d2..0596a61de 100644
--- a/src/modules/procstats/e_mod_main.c
+++ b/src/modules/procstats/e_mod_main.c
@@ -32,6 +32,7 @@ typedef struct
uint64_t mem_size;
uint64_t cpu_time;
uint64_t cpu_time_prev;
+ Eina_Bool was_maximized;
} Proc_Stats_Client;
static void _proc_stats_client_add(E_Client *ec);
@@ -42,6 +43,8 @@ static void _proc_stats_client_del(Proc_Stats_Client *client);
static Eina_Bool _proc_stats_client_gone(Proc_Stats_Client *client);
static void _proc_stats_client_children_update(Eina_List *children, Proc_Stats_Client *client);
static void _proc_stats_client_update(Eina_List *procs, Proc_Stats_Client *client);
+static void _proc_stats_client_popup_add(Proc_Stats_Client *client);
+static void _proc_stats_client_popup_del(Proc_Stats_Client *client);
static Eina_Bool
_memory_total(void)
@@ -91,8 +94,7 @@ _proc_stats_client_exists(E_Client *ec)
static void
_proc_stats_client_del(Proc_Stats_Client *client)
{
- if (client->popup) evas_object_del(client->popup);
- client->popup = NULL;
+ _proc_stats_client_popup_del(client);
edje_object_signal_emit(client->frame_obj, "e,state,procstats,off", "e");
evas_object_del(client->obj);
e_object_delfn_del(E_OBJECT(client->ec), client->delfn);
@@ -109,6 +111,87 @@ _proc_stats_client_del_cb(void *data, void *obj EINA_UNUSED)
_proc_stats_client_remove(client);
}
+static void
+_proc_stats_client_popup_add(Proc_Stats_Client *client)
+{
+ Evas_Object *o, *tb;
+ Evas_Object *pb;
+ Evas_Coord ox, oy, ow, oh;
+ evas_object_geometry_get(client->obj, &ox, &oy, &ow, &oh);
+
+ client->popup = o = elm_ctxpopup_add(e_comp->elm);
+ E_FILL(o); E_EXPAND(o);
+ elm_object_style_set(o, "noblock");
+ evas_object_layer_set(o, E_LAYER_MENU);
+
+ tb = elm_table_add(o);
+ E_FILL(tb); E_EXPAND(tb);
+ elm_object_content_set(o, tb);
+ evas_object_show(tb);
+
+ pb = elm_progressbar_add(o);
+ elm_progressbar_span_size_set(pb, 140);
+ E_FILL(pb); E_EXPAND(pb);
+ elm_table_pack(tb, pb, 0, 0, 1, 1);
+ evas_object_data_set(o, "pb_cpu", pb);
+ evas_object_show(pb);
+
+ pb = elm_progressbar_add(o);
+ elm_progressbar_span_size_set(pb, 140);
+ E_FILL(pb); E_EXPAND(pb);
+ elm_table_pack(tb, pb, 0, 1, 1, 1);
+ evas_object_data_set(o, "pb_mem", pb);
+ evas_object_show(pb);
+
+ _proc_stats_client_display_update(client);
+
+ if (client->ec->maximized)
+ {
+ elm_ctxpopup_direction_priority_set(o, ELM_CTXPOPUP_DIRECTION_DOWN,
+ ELM_CTXPOPUP_DIRECTION_UP,
+ ELM_CTXPOPUP_DIRECTION_LEFT,
+ ELM_CTXPOPUP_DIRECTION_RIGHT);
+ evas_object_move(o, ox + (ow / 2), oy + ow);
+ }
+ else
+ {
+ elm_ctxpopup_direction_priority_set(o, ELM_CTXPOPUP_DIRECTION_UP,
+ ELM_CTXPOPUP_DIRECTION_DOWN,
+ ELM_CTXPOPUP_DIRECTION_LEFT,
+ ELM_CTXPOPUP_DIRECTION_RIGHT);
+ evas_object_move(o, ox + (ow / 2), oy);
+ }
+ evas_object_show(o);
+}
+
+static void
+_proc_stats_client_popup_del(Proc_Stats_Client *client)
+{
+ if (!client) return;
+
+ if (client->popup)
+ evas_object_del(client->popup);
+ client->popup = NULL;
+}
+
+static void
+_proc_stats_client_resize_cb(void *data, Evas *evas EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
+{
+ Proc_Stats_Client *client;
+
+ client = data;
+
+ if ((!client) || (!client->popup)) return;
+
+ if (client->was_maximized != client->ec->maximized)
+ {
+ _proc_stats_client_popup_del(client);
+ _proc_stats_client_popup_add(client);
+ }
+
+ client->was_maximized = client->ec->maximized;
+}
+
static void
_proc_stats_client_move_cb(void *data, Evas *evas EINA_UNUSED, Evas_Object *obj EINA_UNUSED, void *event_info EINA_UNUSED)
{
@@ -133,9 +216,6 @@ _proc_stats_icon_clicked_cb(void *data, Evas *evas EINA_UNUSED, Evas_Object *obj
{
Evas_Event_Mouse_Up *ev;
Proc_Stats_Client *client;
- Evas_Object *o, *tb;
- Evas_Object *pb;
- Evas_Coord ox, oy, ow, oh;
ev = event_info;
client = data;
@@ -146,45 +226,11 @@ _proc_stats_icon_clicked_cb(void *data, Evas *evas EINA_UNUSED, Evas_Object *obj
if (client->popup)
{
- evas_object_del(client->popup);
- client->popup = NULL;
+ _proc_stats_client_popup_del(client);
return;
}
- evas_object_geometry_get(client->obj, &ox, &oy, &ow, &oh);
-
- client->popup = o = elm_ctxpopup_add(e_comp->elm);
- E_FILL(o); E_EXPAND(o);
- elm_object_style_set(o, "noblock");
- evas_object_layer_set(o, E_LAYER_MENU);
-
- tb = elm_table_add(o);
- E_FILL(tb); E_EXPAND(tb);
- elm_object_content_set(o, tb);
- evas_object_show(tb);
-
- pb = elm_progressbar_add(o);
- elm_progressbar_span_size_set(pb, 140);
- E_FILL(pb); E_EXPAND(pb);
- elm_table_pack(tb, pb, 0, 0, 1, 1);
- evas_object_data_set(o, "pb_cpu", pb);
- evas_object_show(pb);
-
- pb = elm_progressbar_add(o);
- elm_progressbar_span_size_set(pb, 140);
- E_FILL(pb); E_EXPAND(pb);
- elm_table_pack(tb, pb, 0, 1, 1, 1);
- evas_object_data_set(o, "pb_mem", pb);
- evas_object_show(pb);
-
- _proc_stats_client_display_update(client);
-
- elm_ctxpopup_direction_priority_set(o, ELM_CTXPOPUP_DIRECTION_UP,
- ELM_CTXPOPUP_DIRECTION_DOWN,
- ELM_CTXPOPUP_DIRECTION_LEFT,
- ELM_CTXPOPUP_DIRECTION_RIGHT);
- evas_object_move(o, ox + (ow / 2), oy);
- evas_object_show(o);
+ _proc_stats_client_popup_add(client);
}
static void
@@ -229,6 +275,7 @@ _proc_stats_client_add(E_Client *ec)
client->delfn = e_object_delfn_add(E_OBJECT(ec), _proc_stats_client_del_cb, client);
evas_object_event_callback_add(client->obj, EVAS_CALLBACK_MOVE, _proc_stats_client_move_cb, client);
evas_object_event_callback_add(client->obj, EVAS_CALLBACK_MOUSE_UP, _proc_stats_icon_clicked_cb, client);
+ evas_object_event_callback_add(client->frame_obj, EVAS_CALLBACK_RESIZE, _proc_stats_client_resize_cb, client);
module->clients = eina_list_append(module->clients, client);
}
--
To stop receiving notification emails like this one, please contact
the administrator of this repository.