2013-06-10 09:17:10 +00:00
|
|
|
/*
|
|
|
|
* Copyright (c) 2013 Red Hat, Inc.
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Lesser General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 2 of the License, or (at your
|
|
|
|
* option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful, but
|
|
|
|
* WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
|
|
|
|
* or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public
|
|
|
|
* License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Lesser General Public License
|
|
|
|
* along with this program; if not, write to the Free Software Foundation,
|
|
|
|
* Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
|
|
|
|
*
|
|
|
|
* Author: Alexander Larsson <alexl@redhat.com>
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef __GTK_LIST_BOX_H__
|
|
|
|
#define __GTK_LIST_BOX_H__
|
|
|
|
|
|
|
|
#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
|
|
|
|
#error "Only <gtk/gtk.h> can be included directly."
|
|
|
|
#endif
|
|
|
|
|
2013-06-15 16:13:28 +00:00
|
|
|
#include <gtk/gtkbin.h>
|
2013-06-10 09:17:10 +00:00
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
|
|
|
|
|
|
|
#define GTK_TYPE_LIST_BOX (gtk_list_box_get_type ())
|
|
|
|
#define GTK_LIST_BOX(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_LIST_BOX, GtkListBox))
|
|
|
|
#define GTK_LIST_BOX_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_LIST_BOX, GtkListBoxClass))
|
|
|
|
#define GTK_IS_LIST_BOX(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_LIST_BOX))
|
|
|
|
#define GTK_IS_LIST_BOX_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_LIST_BOX))
|
|
|
|
#define GTK_LIST_BOX_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_LIST_BOX, GtkListBoxClass))
|
|
|
|
|
2013-06-15 16:13:28 +00:00
|
|
|
typedef struct _GtkListBox GtkListBox;
|
|
|
|
typedef struct _GtkListBoxClass GtkListBoxClass;
|
2013-06-10 09:17:10 +00:00
|
|
|
|
2013-06-15 16:13:28 +00:00
|
|
|
typedef struct _GtkListBoxRow GtkListBoxRow;
|
|
|
|
typedef struct _GtkListBoxRowClass GtkListBoxRowClass;
|
2013-06-10 09:17:10 +00:00
|
|
|
|
|
|
|
struct _GtkListBox
|
|
|
|
{
|
|
|
|
GtkContainer parent_instance;
|
|
|
|
};
|
|
|
|
|
2014-01-17 20:17:45 +00:00
|
|
|
/**
|
|
|
|
* GtkListBoxClass:
|
|
|
|
* @parent_class: The parent class.
|
|
|
|
* @row_selected: Signal emitted when a new row is selected.
|
|
|
|
* @row_activated: Signal emitted when a row has been activated by the user.
|
|
|
|
* @activate_cursor_row:
|
|
|
|
* @toggle_cursor_row:
|
|
|
|
* @move_cursor:
|
|
|
|
*/
|
2013-06-10 09:17:10 +00:00
|
|
|
struct _GtkListBoxClass
|
|
|
|
{
|
|
|
|
GtkContainerClass parent_class;
|
|
|
|
|
2014-01-17 20:17:45 +00:00
|
|
|
/*< public >*/
|
|
|
|
|
2014-03-29 03:07:41 +00:00
|
|
|
void (*row_selected) (GtkListBox *box,
|
2013-06-15 16:13:28 +00:00
|
|
|
GtkListBoxRow *row);
|
2014-03-29 03:07:41 +00:00
|
|
|
void (*row_activated) (GtkListBox *box,
|
2013-06-15 16:13:28 +00:00
|
|
|
GtkListBoxRow *row);
|
2014-03-29 03:07:41 +00:00
|
|
|
void (*activate_cursor_row) (GtkListBox *box);
|
|
|
|
void (*toggle_cursor_row) (GtkListBox *box);
|
|
|
|
void (*move_cursor) (GtkListBox *box,
|
2013-06-15 16:13:28 +00:00
|
|
|
GtkMovementStep step,
|
|
|
|
gint count);
|
2014-03-28 23:21:57 +00:00
|
|
|
void (*selected_rows_changed) (GtkListBox *box);
|
|
|
|
void (*select_all) (GtkListBox *box);
|
|
|
|
void (*unselect_all) (GtkListBox *box);
|
2013-06-10 09:17:10 +00:00
|
|
|
|
2014-01-17 20:17:45 +00:00
|
|
|
/*< private >*/
|
|
|
|
|
2013-06-10 09:17:10 +00:00
|
|
|
/* Padding for future expansion */
|
|
|
|
void (*_gtk_reserved1) (void);
|
|
|
|
void (*_gtk_reserved2) (void);
|
|
|
|
void (*_gtk_reserved3) (void);
|
|
|
|
};
|
|
|
|
|
2013-06-15 16:13:28 +00:00
|
|
|
#define GTK_TYPE_LIST_BOX_ROW (gtk_list_box_row_get_type ())
|
|
|
|
#define GTK_LIST_BOX_ROW(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_LIST_BOX_ROW, GtkListBoxRow))
|
|
|
|
#define GTK_LIST_BOX_ROW_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_LIST_BOX_ROW, GtkListBoxRowClass))
|
|
|
|
#define GTK_IS_LIST_BOX_ROW(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_LIST_BOX_ROW))
|
2013-06-10 09:17:10 +00:00
|
|
|
#define GTK_IS_LIST_BOX_ROW_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_LIST_BOX_ROW))
|
2013-06-15 16:13:28 +00:00
|
|
|
#define GTK_LIST_BOX_ROW_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_LIST_BOX_ROW, GtkListBoxRowClass))
|
2013-06-10 09:17:10 +00:00
|
|
|
|
|
|
|
struct _GtkListBoxRow
|
|
|
|
{
|
|
|
|
GtkBin parent_instance;
|
|
|
|
};
|
|
|
|
|
2014-01-17 20:17:45 +00:00
|
|
|
/**
|
|
|
|
* GtkListBoxRowClass:
|
|
|
|
* @parent_class: The parent class.
|
|
|
|
* @activate:
|
|
|
|
*/
|
2013-06-10 09:17:10 +00:00
|
|
|
struct _GtkListBoxRowClass
|
|
|
|
{
|
|
|
|
GtkBinClass parent_class;
|
|
|
|
|
2014-01-17 20:17:45 +00:00
|
|
|
/*< public >*/
|
|
|
|
|
2013-09-10 12:12:07 +00:00
|
|
|
void (* activate) (GtkListBoxRow *row);
|
|
|
|
|
2014-01-17 20:17:45 +00:00
|
|
|
/*< private >*/
|
|
|
|
|
2013-06-10 09:17:10 +00:00
|
|
|
/* Padding for future expansion */
|
|
|
|
void (*_gtk_reserved1) (void);
|
|
|
|
void (*_gtk_reserved2) (void);
|
|
|
|
};
|
|
|
|
|
2013-06-11 10:59:32 +00:00
|
|
|
/**
|
|
|
|
* GtkListBoxFilterFunc:
|
2013-06-15 16:13:28 +00:00
|
|
|
* @row: the row that may be filtered
|
|
|
|
* @user_data: (closure): user data
|
2013-06-11 10:59:32 +00:00
|
|
|
*
|
|
|
|
* Will be called whenever the row changes or is added and lets you control
|
|
|
|
* if the row should be visible or not.
|
|
|
|
*
|
|
|
|
* Returns: %TRUE if the row should be visible, %FALSE otherwise
|
|
|
|
*
|
|
|
|
* Since: 3.10
|
|
|
|
*/
|
2013-06-15 16:13:28 +00:00
|
|
|
typedef gboolean (*GtkListBoxFilterFunc) (GtkListBoxRow *row,
|
|
|
|
gpointer user_data);
|
|
|
|
|
2013-06-11 10:59:32 +00:00
|
|
|
/**
|
|
|
|
* GtkListBoxSortFunc:
|
2013-06-15 16:13:28 +00:00
|
|
|
* @row1: the first row
|
|
|
|
* @row2: the second row
|
|
|
|
* @user_data: (closure): user data
|
2013-06-11 10:59:32 +00:00
|
|
|
*
|
2013-09-21 00:16:00 +00:00
|
|
|
* Compare two rows to determine which should be first.
|
2013-06-11 10:59:32 +00:00
|
|
|
*
|
2013-06-15 16:13:28 +00:00
|
|
|
* Returns: < 0 if @row1 should be before @row2, 0 if they are
|
|
|
|
* equal and > 0 otherwise
|
2013-06-11 10:59:32 +00:00
|
|
|
*
|
|
|
|
* Since: 3.10
|
|
|
|
*/
|
|
|
|
typedef gint (*GtkListBoxSortFunc) (GtkListBoxRow *row1,
|
|
|
|
GtkListBoxRow *row2,
|
|
|
|
gpointer user_data);
|
2013-06-15 16:13:28 +00:00
|
|
|
|
2013-06-11 10:59:32 +00:00
|
|
|
/**
|
2013-06-11 12:09:19 +00:00
|
|
|
* GtkListBoxUpdateHeaderFunc:
|
2013-06-15 16:13:28 +00:00
|
|
|
* @row: the row to update
|
2013-09-16 18:08:35 +00:00
|
|
|
* @before: (allow-none): the row before @row, or %NULL if it is first
|
2013-06-15 16:13:28 +00:00
|
|
|
* @user_data: (closure): user data
|
2013-06-11 10:59:32 +00:00
|
|
|
*
|
2013-06-15 16:13:28 +00:00
|
|
|
* Whenever @row changes or which row is before @row changes this
|
|
|
|
* is called, which lets you update the header on @row. You may
|
|
|
|
* remove or set a new one via gtk_list_box_row_set_header() or
|
|
|
|
* just change the state of the current header widget.
|
2013-06-11 10:59:32 +00:00
|
|
|
*
|
|
|
|
* Since: 3.10
|
|
|
|
*/
|
2013-06-11 12:09:19 +00:00
|
|
|
typedef void (*GtkListBoxUpdateHeaderFunc) (GtkListBoxRow *row,
|
|
|
|
GtkListBoxRow *before,
|
|
|
|
gpointer user_data);
|
2013-06-10 09:17:10 +00:00
|
|
|
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
|
|
|
GType gtk_list_box_row_get_type (void) G_GNUC_CONST;
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
|
|
|
GtkWidget* gtk_list_box_row_new (void);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2013-06-11 12:09:19 +00:00
|
|
|
GtkWidget* gtk_list_box_row_get_header (GtkListBoxRow *row);
|
2013-06-10 09:17:10 +00:00
|
|
|
GDK_AVAILABLE_IN_3_10
|
2013-06-11 12:09:19 +00:00
|
|
|
void gtk_list_box_row_set_header (GtkListBoxRow *row,
|
|
|
|
GtkWidget *header);
|
2013-06-10 09:17:10 +00:00
|
|
|
GDK_AVAILABLE_IN_3_10
|
2013-07-04 11:40:21 +00:00
|
|
|
gint gtk_list_box_row_get_index (GtkListBoxRow *row);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2013-06-10 09:17:10 +00:00
|
|
|
void gtk_list_box_row_changed (GtkListBoxRow *row);
|
|
|
|
|
2014-03-28 23:21:57 +00:00
|
|
|
GDK_AVAILABLE_IN_3_14
|
|
|
|
gboolean gtk_list_box_row_is_selected (GtkListBoxRow *row);
|
2013-06-10 09:17:10 +00:00
|
|
|
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
|
|
|
GType gtk_list_box_get_type (void) G_GNUC_CONST;
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_prepend (GtkListBox *box,
|
2013-08-06 12:57:22 +00:00
|
|
|
GtkWidget *child);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_insert (GtkListBox *box,
|
2013-08-07 10:36:03 +00:00
|
|
|
GtkWidget *child,
|
|
|
|
gint position);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
GtkListBoxRow* gtk_list_box_get_selected_row (GtkListBox *box);
|
2013-06-10 09:17:10 +00:00
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
GtkListBoxRow* gtk_list_box_get_row_at_index (GtkListBox *box,
|
2013-06-15 16:13:28 +00:00
|
|
|
gint index_);
|
2013-06-10 09:17:10 +00:00
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
GtkListBoxRow* gtk_list_box_get_row_at_y (GtkListBox *box,
|
2013-06-10 09:17:10 +00:00
|
|
|
gint y);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_select_row (GtkListBox *box,
|
2013-06-10 09:17:10 +00:00
|
|
|
GtkListBoxRow *row);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_set_placeholder (GtkListBox *box,
|
2013-06-11 14:53:31 +00:00
|
|
|
GtkWidget *placeholder);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_set_adjustment (GtkListBox *box,
|
2013-06-10 09:17:10 +00:00
|
|
|
GtkAdjustment *adjustment);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
GtkAdjustment *gtk_list_box_get_adjustment (GtkListBox *box);
|
2014-03-28 23:21:57 +00:00
|
|
|
|
|
|
|
typedef void (* GtkListBoxForeachFunc) (GtkListBox *box,
|
|
|
|
GtkListBoxRow *row,
|
|
|
|
gpointer user_data);
|
|
|
|
|
|
|
|
GDK_AVAILABLE_IN_3_14
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_selected_foreach (GtkListBox *box,
|
2014-03-28 23:21:57 +00:00
|
|
|
GtkListBoxForeachFunc func,
|
|
|
|
gpointer data);
|
|
|
|
GDK_AVAILABLE_IN_3_14
|
2014-03-29 03:07:41 +00:00
|
|
|
GList *gtk_list_box_get_selected_rows (GtkListBox *box);
|
2014-03-28 23:21:57 +00:00
|
|
|
GDK_AVAILABLE_IN_3_14
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_unselect_row (GtkListBox *box,
|
2014-03-28 23:21:57 +00:00
|
|
|
GtkListBoxRow *row);
|
|
|
|
GDK_AVAILABLE_IN_3_14
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_select_all (GtkListBox *box);
|
2014-03-28 23:21:57 +00:00
|
|
|
GDK_AVAILABLE_IN_3_14
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_unselect_all (GtkListBox *box);
|
2014-03-28 23:21:57 +00:00
|
|
|
|
2013-06-10 09:17:10 +00:00
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_set_selection_mode (GtkListBox *box,
|
2013-06-10 09:17:10 +00:00
|
|
|
GtkSelectionMode mode);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
GtkSelectionMode gtk_list_box_get_selection_mode (GtkListBox *box);
|
2013-06-10 09:17:10 +00:00
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_set_filter_func (GtkListBox *box,
|
2013-06-10 09:17:10 +00:00
|
|
|
GtkListBoxFilterFunc filter_func,
|
|
|
|
gpointer user_data,
|
|
|
|
GDestroyNotify destroy);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_set_header_func (GtkListBox *box,
|
2013-06-11 12:09:19 +00:00
|
|
|
GtkListBoxUpdateHeaderFunc update_header,
|
2013-06-10 09:17:10 +00:00
|
|
|
gpointer user_data,
|
|
|
|
GDestroyNotify destroy);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_invalidate_filter (GtkListBox *box);
|
2013-06-10 09:17:10 +00:00
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_invalidate_sort (GtkListBox *box);
|
2013-06-10 09:17:10 +00:00
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_invalidate_headers (GtkListBox *box);
|
2013-06-10 09:17:10 +00:00
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_set_sort_func (GtkListBox *box,
|
2013-06-10 09:17:10 +00:00
|
|
|
GtkListBoxSortFunc sort_func,
|
|
|
|
gpointer user_data,
|
|
|
|
GDestroyNotify destroy);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_set_activate_on_single_click (GtkListBox *box,
|
2013-06-10 09:17:10 +00:00
|
|
|
gboolean single);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
gboolean gtk_list_box_get_activate_on_single_click (GtkListBox *box);
|
2013-06-12 07:40:06 +00:00
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_drag_unhighlight_row (GtkListBox *box);
|
2013-06-10 09:17:10 +00:00
|
|
|
GDK_AVAILABLE_IN_3_10
|
2014-03-29 03:07:41 +00:00
|
|
|
void gtk_list_box_drag_highlight_row (GtkListBox *box,
|
2013-06-10 09:17:10 +00:00
|
|
|
GtkListBoxRow *row);
|
|
|
|
GDK_AVAILABLE_IN_3_10
|
|
|
|
GtkWidget* gtk_list_box_new (void);
|
|
|
|
|
|
|
|
|
2014-03-28 23:21:57 +00:00
|
|
|
|
2013-06-10 09:17:10 +00:00
|
|
|
G_END_DECLS
|
|
|
|
|
|
|
|
#endif
|