Genlist: restore old behaviour of item next/prev in group items

Commit fd82c2521 has changed the behaviour of item_next/prev_get()
in case of genlist with group items (not tree).

The lagacy behaviour was to tread normal items and group items
in a flat way, like if group items was on the same level of
the children normal items.

As the commit already implement bug compatibility, seems to me
the case to restore also this case. Note that this changes only
apply to legacy genlist (I think).

Let me know if this broke something for you...as touching genlist
code is always an "I hope this is right" operation.
This commit is contained in:
Davide Andreoli 2018-04-13 20:37:36 +02:00
parent 703277b242
commit f0a0da9f44
1 changed files with 18 additions and 2 deletions

View File

@ -6958,6 +6958,12 @@ _elm_genlist_next_item_get_insane(Elm_Genlist_Data *sd, Elm_Gen_Item *it)
if (sd->filter && !_item_filtered_get(it2))
continue;
// Insanity does not apply for group items
// (group and normal items was treated in a flat way)
if (it->item->type == ELM_GENLIST_ITEM_GROUP ||
it2->item->type == ELM_GENLIST_ITEM_GROUP)
return EO_OBJ(it2);
// 1. Return next sibling in list, if any
if (it->parent == it2->parent)
return EO_OBJ(it2);
@ -6981,7 +6987,7 @@ _elm_genlist_next_item_get_insane(Elm_Genlist_Data *sd, Elm_Gen_Item *it)
return EO_OBJ(it->parent);
}
/* if item is already last item, return its parent if a parent exists */
if (it->parent)
if (it->parent && it->parent->item->type != ELM_GENLIST_ITEM_GROUP)
return EO_OBJ(it->parent);
return EO_OBJ(it2);
}
@ -7001,6 +7007,16 @@ _elm_genlist_prev_item_get_insane(Elm_Genlist_Data *sd, Elm_Gen_Item *it)
return EO_OBJ(it2);
}
// Insanity does not apply for group items
// (group and normal items was treated in a flat way)
if (it->item->type == ELM_GENLIST_ITEM_GROUP)
{
for (it2 = ELM_GEN_ITEM_PREV(it); it2; it2 = ELM_GEN_ITEM_PREV(it2))
if (!sd->filter || _item_filtered_get(it2))
break;
return EO_OBJ(it2);
}
parent = it->parent;
if (!parent)
{
@ -7020,7 +7036,7 @@ _elm_genlist_prev_item_get_insane(Elm_Genlist_Data *sd, Elm_Gen_Item *it)
}
it2 = ELM_GEN_ITEM_PREV(it);
if (it2 == parent)
if (it2 == parent && it2->item->type != ELM_GENLIST_ITEM_GROUP)
return _elm_genlist_prev_item_get_insane(sd, it2);
return EO_OBJ(it2);