2 * @defgroup Index Index
4 * @image html img/widget/index/preview-00.png
5 * @image latex img/widget/index/preview-00.eps
7 * An index widget gives you an index for fast access to whichever
8 * group of other UI items one might have. It's a list of text
9 * items (usually letters, for alphabetically ordered access).
11 * Index widgets are by default hidden and just appear when the
12 * user clicks over it's reserved area in the canvas. In its
13 * default theme, it's an area one @ref Fingers "finger" wide on
14 * the right side of the index widget's container.
16 * When items on the index are selected, smart callbacks get
17 * called, so that its user can make other container objects to
18 * show a given area or child object depending on the index item
19 * selected. You'd probably be using an index together with @ref
20 * List "lists", @ref Genlist "generic lists" or @ref Gengrid
23 * Smart events one can add callbacks for are:
24 * - @c "changed" - When the selected index item changes. @c
25 * event_info is the selected item's data pointer.
26 * - @c "delay,changed" - When the selected index item changes, but
27 * after a small idling period. @c event_info is the selected
28 * item's data pointer.
29 * - @c "selected" - When the user releases a mouse button and
30 * selects an item. @c event_info is the selected item's data
32 * - @c "level,up" - when the user moves a finger from the first
33 * level to the second level
34 * - @c "level,down" - when the user moves a finger from the second
35 * level to the first level
37 * The @c "delay,changed" event is so that it'll wait a small time
38 * before actually reporting those events and, moreover, just the
39 * last event happening on those time frames will actually be
42 * Here are some examples on its usage:
43 * @li @ref index_example_01
44 * @li @ref index_example_02
52 * Add a new index widget to the given parent Elementary
55 * @param parent The parent object
56 * @return a new index widget handle or @c NULL, on errors
58 * This function inserts a new index widget on the canvas.
62 EAPI Evas_Object *elm_index_add(Evas_Object *parent);
65 * Enable or disable auto hiding feature for a given index widget.
67 * @param obj The index object
68 * @param disabled @c EINA_TRUE to disable auto hiding, @c EINA_FALSE to enable
70 * @see elm_index_autohide_disabled_get()
74 EAPI void elm_index_autohide_disabled_set(Evas_Object *obj, Eina_Bool disabled);
77 * Get whether auto hiding feature is enabled or not for a given index widget.
79 * @param obj The index object
80 * @return @c EINA_TRUE, if auto hiding is disabled, @c EINA_FALSE otherwise
82 * @see elm_index_autohide_disabled_set() for more details
86 EAPI Eina_Bool elm_index_autohide_disabled_get(const Evas_Object *obj);
89 * Set the items level for a given index widget.
91 * @param obj The index object.
92 * @param level @c 0 or @c 1, the currently implemented levels.
94 * @see elm_index_item_level_get()
98 EAPI void elm_index_item_level_set(Evas_Object *obj, int level);
101 * Get the items level set for a given index widget.
103 * @param obj The index object.
104 * @return @c 0 or @c 1, which are the levels @p obj might be at.
106 * @see elm_index_item_level_set() for more information
110 EAPI int elm_index_item_level_get(const Evas_Object *obj);
113 * Set the selected state of an item.
115 * @param it The index item
116 * @param selected The selected state
118 * This sets the selected state of the given item @p it.
119 * @c EINA_TRUE for selected, @c EINA_FALSE for not selected.
121 * If a new item is selected the previously selected will be unselected.
122 * Previously selected item can be get with function
123 * elm_index_selected_item_get().
125 * Selected items will be highlighted.
127 * @see elm_index_selected_item_get()
131 EAPI void elm_index_item_selected_set(Elm_Object_Item *it, Eina_Bool selected);
134 * Returns the last selected item, for a given index widget.
136 * @param obj The index object.
137 * @param level @c 0 or @c 1, the currently implemented levels.
138 * @return The last item @b selected on @p obj (or @c NULL, on errors).
142 EAPI Elm_Object_Item *elm_index_selected_item_get(const Evas_Object *obj, int level);
145 * Append a new item on a given index widget.
147 * @param obj The index object.
148 * @param letter Letter under which the item should be indexed
149 * @param func The function to call when the item is selected.
150 * @param data The item data to set for the index's item
151 * @return A handle to the item added or @c NULL, on errors
153 * Despite the most common usage of the @p letter argument is for
154 * single char strings, one could use arbitrary strings as index
157 * @c item will be the pointer returned back on @c "changed", @c
158 * "delay,changed" and @c "selected" smart events.
162 EAPI Elm_Object_Item *elm_index_item_append(Evas_Object *obj, const char *letter, Evas_Smart_Cb func, const void *data);
165 * Prepend a new item on a given index widget.
167 * @param obj The index object.
168 * @param letter Letter under which the item should be indexed
169 * @param func The function to call when the item is selected.
170 * @param data The item data to set for the index's item
171 * @return A handle to the item added or @c NULL, on errors
173 * Despite the most common usage of the @p letter argument is for
174 * single char strings, one could use arbitrary strings as index
177 * @c item will be the pointer returned back on @c "changed", @c
178 * "delay,changed" and @c "selected" smart events.
182 EAPI Elm_Object_Item *elm_index_item_prepend(Evas_Object *obj, const char *letter, Evas_Smart_Cb func, const void *data);
185 * Insert a new item into the index object after item @p after.
187 * @param obj The index object.
188 * @param after The index item to insert after.
189 * @param letter Letter under which the item should be indexed
190 * @param func The function to call when the item is clicked.
191 * @param data The item data to set for the index's item
192 * @return A handle to the item added or @c NULL, on errors
194 * Despite the most common usage of the @p letter argument is for
195 * single char strings, one could use arbitrary strings as index
198 * @c item will be the pointer returned back on @c "changed", @c
199 * "delay,changed" and @c "selected" smart events.
201 * @note If @p relative is @c NULL this function will behave as
202 * elm_index_item_append().
206 EAPI Elm_Object_Item *elm_index_item_insert_after(Evas_Object *obj, Elm_Object_Item *after, const char *letter, Evas_Smart_Cb func, const void *data);
209 * Insert a new item into the index object before item @p before.
211 * @param obj The index object.
212 * @param before The index item to insert after.
213 * @param letter Letter under which the item should be indexed
214 * @param func The function to call when the item is clicked.
215 * @param data The item data to set for the index's item
216 * @return A handle to the item added or @c NULL, on errors
218 * Despite the most common usage of the @p letter argument is for
219 * single char strings, one could use arbitrary strings as index
222 * @c item will be the pointer returned back on @c "changed", @c
223 * "delay,changed" and @c "selected" smart events.
225 * @note If @p relative is @c NULL this function will behave as
226 * elm_index_item_prepend().
230 EAPI Elm_Object_Item *elm_index_item_insert_before(Evas_Object *obj, Elm_Object_Item *before, const char *letter, Evas_Smart_Cb func, const void *data);
233 * Insert a new item into the given index widget, using @p cmp_func
234 * function to sort items (by item handles).
236 * @param obj The index object.
237 * @param letter Letter under which the item should be indexed
238 * @param func The function to call when the item is clicked.
239 * @param data The item data to set for the index's item
240 * @param cmp_func The comparing function to be used to sort index
241 * items <b>by #index item handles</b>
242 * @param cmp_data_func A @b fallback function to be called for the
243 * sorting of index items <b>by item data</b>). It will be used
244 * when @p cmp_func returns @c 0 (equality), which means an index
245 * item with provided item data already exists. To decide which
246 * data item should be pointed to by the index item in question, @p
247 * cmp_data_func will be used. If @p cmp_data_func returns a
248 * non-negative value, the previous index item data will be
249 * replaced by the given @p item pointer. If the previous data need
250 * to be freed, it should be done by the @p cmp_data_func function,
251 * because all references to it will be lost. If this function is
252 * not provided (@c NULL is given), index items will be @b
253 * duplicated, if @p cmp_func returns @c 0.
254 * @return A handle to the item added or @c NULL, on errors
256 * Despite the most common usage of the @p letter argument is for
257 * single char strings, one could use arbitrary strings as index
260 * @c item will be the pointer returned back on @c "changed", @c
261 * "delay,changed" and @c "selected" smart events.
265 EAPI Elm_Object_Item *elm_index_item_sorted_insert(Evas_Object *obj, const char *letter, Evas_Smart_Cb func, const void *data, Eina_Compare_Cb cmp_func, Eina_Compare_Cb cmp_data_func);
268 * Find a given index widget's item, <b>using item data</b>.
270 * @param obj The index object
271 * @param data The item data pointed to by the desired index item
272 * @return The index item handle, if found, or @c NULL otherwise
276 EAPI Elm_Object_Item *elm_index_item_find(Evas_Object *obj, const void *data);
279 * Removes @b all items from a given index widget.
281 * @param obj The index object.
283 * If deletion callbacks are set, via elm_object_item_del_cb_set(),
284 * that callback function will be called for each item in @p obj.
288 EAPI void elm_index_item_clear(Evas_Object *obj);
291 * Go to a given items level on a index widget
293 * @param obj The index object
294 * @param level The index level (one of @c 0 or @c 1)
298 EAPI void elm_index_level_go(Evas_Object *obj, int level);
301 * Get the letter (string) set on a given index widget item.
303 * @param item The index item handle
304 * @return The letter string set on @p it
308 EAPI const char *elm_index_item_letter_get(const Elm_Object_Item *item);
311 * Set the indicator as to be disabled.
313 * @param obj The index object
314 * @param disabled @c EINA_TRUE to disable it, @c EINA_FALSE to enable it
316 * In Index widget, Indicator notes popup text, which shows a letter has been selecting.
318 * @see elm_index_indicator_disabled_get()
322 EAPI void elm_index_indicator_disabled_set(Evas_Object *obj, Eina_Bool disabled);
325 * Get the value of indicator's disabled status.
327 * @param obj The index object
328 * @return EINA_TRUE if the indicator is disabled.
330 * @see elm_index_indicator_disabled_set()
334 EAPI Eina_Bool elm_index_indicator_disabled_get(const Evas_Object *obj);
337 * Enable or disable horizontal mode on the index object
339 * @param obj The index object.
340 * @param horizontal @c EINA_TRUE to enable horizontal or @c EINA_FALSE to
341 * disable it, i.e., to enable vertical mode. it's an area one @ref Fingers
342 * "finger" wide on the bottom side of the index widget's container.
344 * @note Vertical mode is set by default.
346 * On horizontal mode items are displayed on index from left to right,
347 * instead of from top to bottom. Also, the index will scroll horizontally.
349 * @see elm_index_horizontal_get()
353 EAPI void elm_index_horizontal_set(Evas_Object *obj, Eina_Bool horizontal);
356 * Get a value whether horizontal mode is enabled or not.
358 * @param obj The index object.
359 * @return @c EINA_TRUE means horizontal mode selection is enabled.
360 * @c EINA_FALSE indicates it's disabled. If @p obj is @c NULL,
361 * @c EINA_FALSE is returned.
363 * @see elm_index_horizontal_set() for details.
367 EAPI Eina_Bool elm_index_horizontal_get(const Evas_Object *obj);