2006-01-19 13:38:50 +00:00
|
|
|
|
/*
|
2008-07-01 22:57:50 +00:00
|
|
|
|
* GTK - The GIMP Toolkit
|
2006-01-19 13:38:50 +00:00
|
|
|
|
* Copyright (C) 1999 Red Hat, Inc.
|
|
|
|
|
* Copyright (C) 2002 Anders Carlsson <andersca@gnu.org>
|
|
|
|
|
* Copyright (C) 2003 Matthias Clasen <mclasen@redhat.com>
|
|
|
|
|
* Copyright (C) 2005 Carlos Garnacho Parro <carlosg@gnome.org>
|
|
|
|
|
*
|
|
|
|
|
* All rights reserved.
|
|
|
|
|
*
|
|
|
|
|
* This library 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 library 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
|
2012-02-27 13:01:10 +00:00
|
|
|
|
* License along with this library. If not, see <http://www.gnu.org/licenses/>.
|
2006-01-19 13:38:50 +00:00
|
|
|
|
*/
|
|
|
|
|
|
2012-12-28 14:57:34 +00:00
|
|
|
|
#ifndef __GTK_ASSISTANT_H__
|
|
|
|
|
#define __GTK_ASSISTANT_H__
|
|
|
|
|
|
2009-10-21 18:30:04 +00:00
|
|
|
|
#if !defined (__GTK_H_INSIDE__) && !defined (GTK_COMPILATION)
|
2008-05-28 15:07:04 +00:00
|
|
|
|
#error "Only <gtk/gtk.h> can be included directly."
|
|
|
|
|
#endif
|
|
|
|
|
|
2006-01-19 13:38:50 +00:00
|
|
|
|
#include <gtk/gtkwindow.h>
|
|
|
|
|
|
|
|
|
|
G_BEGIN_DECLS
|
|
|
|
|
|
|
|
|
|
#define GTK_TYPE_ASSISTANT (gtk_assistant_get_type ())
|
|
|
|
|
#define GTK_ASSISTANT(o) (G_TYPE_CHECK_INSTANCE_CAST ((o), GTK_TYPE_ASSISTANT, GtkAssistant))
|
|
|
|
|
#define GTK_ASSISTANT_CLASS(c) (G_TYPE_CHECK_CLASS_CAST ((c), GTK_TYPE_ASSISTANT, GtkAssistantClass))
|
|
|
|
|
#define GTK_IS_ASSISTANT(o) (G_TYPE_CHECK_INSTANCE_TYPE ((o), GTK_TYPE_ASSISTANT))
|
|
|
|
|
#define GTK_IS_ASSISTANT_CLASS(c) (G_TYPE_CHECK_CLASS_TYPE ((c), GTK_TYPE_ASSISTANT))
|
|
|
|
|
#define GTK_ASSISTANT_GET_CLASS(o) (G_TYPE_INSTANCE_GET_CLASS ((o), GTK_TYPE_ASSISTANT, GtkAssistantClass))
|
|
|
|
|
|
2010-03-05 22:44:31 +00:00
|
|
|
|
/**
|
|
|
|
|
* GtkAssistantPageType:
|
2010-10-30 18:57:55 +00:00
|
|
|
|
* @GTK_ASSISTANT_PAGE_CONTENT: The page has regular contents. Both the
|
|
|
|
|
* Back and forward buttons will be shown.
|
2010-03-05 22:44:31 +00:00
|
|
|
|
* @GTK_ASSISTANT_PAGE_INTRO: The page contains an introduction to the
|
2010-10-30 18:57:55 +00:00
|
|
|
|
* assistant task. Only the Forward button will be shown if there is a
|
|
|
|
|
* next page.
|
2010-03-05 22:44:31 +00:00
|
|
|
|
* @GTK_ASSISTANT_PAGE_CONFIRM: The page lets the user confirm or deny the
|
2010-10-30 18:57:55 +00:00
|
|
|
|
* changes. The Back and Apply buttons will be shown.
|
2010-03-05 22:44:31 +00:00
|
|
|
|
* @GTK_ASSISTANT_PAGE_SUMMARY: The page informs the user of the changes
|
2010-10-30 18:57:55 +00:00
|
|
|
|
* done. Only the Close button will be shown.
|
2010-03-05 22:44:31 +00:00
|
|
|
|
* @GTK_ASSISTANT_PAGE_PROGRESS: Used for tasks that take a long time to
|
|
|
|
|
* complete, blocks the assistant until the page is marked as complete.
|
2010-10-30 18:57:55 +00:00
|
|
|
|
* Only the back button will be shown.
|
2010-10-30 19:12:58 +00:00
|
|
|
|
* @GTK_ASSISTANT_PAGE_CUSTOM: Used for when other page types are not
|
|
|
|
|
* appropriate. No buttons will be shown, and the application must
|
|
|
|
|
* add its own buttons through gtk_assistant_add_action_widget().
|
2010-03-05 22:44:31 +00:00
|
|
|
|
*
|
|
|
|
|
* An enum for determining the page role inside the #GtkAssistant. It's
|
|
|
|
|
* used to handle buttons sensitivity and visibility.
|
|
|
|
|
*
|
|
|
|
|
* Note that an assistant needs to end its page flow with a page of type
|
2010-06-02 20:00:16 +00:00
|
|
|
|
* %GTK_ASSISTANT_PAGE_CONFIRM, %GTK_ASSISTANT_PAGE_SUMMARY or
|
|
|
|
|
* %GTK_ASSISTANT_PAGE_PROGRESS to be correct.
|
2010-10-30 18:57:55 +00:00
|
|
|
|
*
|
2014-02-07 18:32:47 +00:00
|
|
|
|
* The Cancel button will only be shown if the page isn’t “committed”.
|
2010-10-30 18:57:55 +00:00
|
|
|
|
* See gtk_assistant_commit() for details.
|
2010-03-05 22:44:31 +00:00
|
|
|
|
*/
|
2006-01-19 13:38:50 +00:00
|
|
|
|
typedef enum
|
|
|
|
|
{
|
|
|
|
|
GTK_ASSISTANT_PAGE_CONTENT,
|
|
|
|
|
GTK_ASSISTANT_PAGE_INTRO,
|
|
|
|
|
GTK_ASSISTANT_PAGE_CONFIRM,
|
|
|
|
|
GTK_ASSISTANT_PAGE_SUMMARY,
|
2010-10-30 19:12:58 +00:00
|
|
|
|
GTK_ASSISTANT_PAGE_PROGRESS,
|
|
|
|
|
GTK_ASSISTANT_PAGE_CUSTOM
|
2006-01-19 13:38:50 +00:00
|
|
|
|
} GtkAssistantPageType;
|
|
|
|
|
|
2006-01-19 16:51:21 +00:00
|
|
|
|
typedef struct _GtkAssistant GtkAssistant;
|
|
|
|
|
typedef struct _GtkAssistantPrivate GtkAssistantPrivate;
|
|
|
|
|
typedef struct _GtkAssistantClass GtkAssistantClass;
|
2006-01-19 13:38:50 +00:00
|
|
|
|
|
|
|
|
|
struct _GtkAssistant
|
|
|
|
|
{
|
|
|
|
|
GtkWindow parent;
|
|
|
|
|
|
2006-01-19 16:51:21 +00:00
|
|
|
|
/*< private >*/
|
2010-05-24 13:46:51 +00:00
|
|
|
|
GtkAssistantPrivate *priv;
|
2006-01-19 13:38:50 +00:00
|
|
|
|
};
|
|
|
|
|
|
2014-01-17 20:17:45 +00:00
|
|
|
|
/**
|
|
|
|
|
* GtkAssistantClass:
|
|
|
|
|
* @parent_class: The parent class.
|
2014-02-07 18:01:26 +00:00
|
|
|
|
* @prepare: Signal emitted when a new page is set as the assistant’s current page, before making the new page visible.
|
2014-01-17 20:17:45 +00:00
|
|
|
|
* @apply: Signal emitted when the apply button is clicked.
|
|
|
|
|
* @close: Signal emitted either when the close button or last page apply button is clicked.
|
|
|
|
|
* @cancel: Signal emitted when the cancel button is clicked.
|
|
|
|
|
*/
|
2006-01-19 13:38:50 +00:00
|
|
|
|
struct _GtkAssistantClass
|
|
|
|
|
{
|
|
|
|
|
GtkWindowClass parent_class;
|
|
|
|
|
|
2014-01-17 20:17:45 +00:00
|
|
|
|
/*< public >*/
|
|
|
|
|
|
2006-02-10 12:59:19 +00:00
|
|
|
|
void (* prepare) (GtkAssistant *assistant, GtkWidget *page);
|
2006-01-19 13:38:50 +00:00
|
|
|
|
void (* apply) (GtkAssistant *assistant);
|
|
|
|
|
void (* close) (GtkAssistant *assistant);
|
|
|
|
|
void (* cancel) (GtkAssistant *assistant);
|
|
|
|
|
|
2014-01-17 20:17:45 +00:00
|
|
|
|
/*< private >*/
|
|
|
|
|
|
2006-01-19 13:38:50 +00:00
|
|
|
|
/* Padding for future expansion */
|
|
|
|
|
void (*_gtk_reserved1) (void);
|
|
|
|
|
void (*_gtk_reserved2) (void);
|
|
|
|
|
void (*_gtk_reserved3) (void);
|
|
|
|
|
void (*_gtk_reserved4) (void);
|
|
|
|
|
void (*_gtk_reserved5) (void);
|
|
|
|
|
};
|
|
|
|
|
|
2019-02-07 20:18:49 +00:00
|
|
|
|
#define GTK_TYPE_ASSISTANT_PAGE (gtk_assistant_page_get_type ())
|
|
|
|
|
#define GTK_ASSISTANT_PAGE(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), GTK_TYPE_ASSISTANT_PAGE, GtkAssistantPage))
|
|
|
|
|
#define GTK_ASSISTANT_PAGE_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), GTK_TYPE_ASSISTANT_PAGE, GtkAssistantPageClass))
|
|
|
|
|
#define GTK_IS_ASSISTANT_PAGE(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), GTK_TYPE_ASSISTANT_PAGE))
|
|
|
|
|
#define GTK_IS_ASSISTANT_PAGE_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((klass), GTK_TYPE_ASSISTANT_PAGE))
|
|
|
|
|
#define GTK_ASSISTANT_PAGE_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS ((obj), GTK_TYPE_ASSISTANT_PAGE, GtkAssistantPageClass))
|
|
|
|
|
|
|
|
|
|
typedef struct _GtkAssistantPage GtkAssistantPage;
|
|
|
|
|
typedef struct _GtkAssistantPageClass GtkAssistantPageClass;
|
|
|
|
|
|
2010-03-05 22:44:31 +00:00
|
|
|
|
/**
|
|
|
|
|
* GtkAssistantPageFunc:
|
|
|
|
|
* @current_page: The page number used to calculate the next page.
|
2011-01-18 05:28:24 +00:00
|
|
|
|
* @data: (closure): user data.
|
2010-03-05 22:44:31 +00:00
|
|
|
|
*
|
|
|
|
|
* A function used by gtk_assistant_set_forward_page_func() to know which
|
2014-02-07 18:01:26 +00:00
|
|
|
|
* is the next page given a current one. It’s called both for computing the
|
2014-02-05 18:07:34 +00:00
|
|
|
|
* next page when the user presses the “forward” button and for handling
|
|
|
|
|
* the behavior of the “last” button.
|
2010-03-05 22:44:31 +00:00
|
|
|
|
*
|
|
|
|
|
* Returns: The next page number.
|
|
|
|
|
*/
|
2006-01-19 13:38:50 +00:00
|
|
|
|
typedef gint (*GtkAssistantPageFunc) (gint current_page, gpointer data);
|
|
|
|
|
|
2019-02-07 20:18:49 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
|
|
|
|
GType gtk_assistant_page_get_type (void) G_GNUC_CONST;
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
GType gtk_assistant_get_type (void) G_GNUC_CONST;
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
GtkWidget *gtk_assistant_new (void);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2010-10-30 19:12:58 +00:00
|
|
|
|
void gtk_assistant_next_page (GtkAssistant *assistant);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2010-10-30 19:12:58 +00:00
|
|
|
|
void gtk_assistant_previous_page (GtkAssistant *assistant);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
gint gtk_assistant_get_current_page (GtkAssistant *assistant);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
void gtk_assistant_set_current_page (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
gint page_num);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
gint gtk_assistant_get_n_pages (GtkAssistant *assistant);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
GtkWidget *gtk_assistant_get_nth_page (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
gint page_num);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
gint gtk_assistant_prepend_page (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
GtkWidget *page);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
gint gtk_assistant_append_page (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
GtkWidget *page);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
gint gtk_assistant_insert_page (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
GtkWidget *page,
|
|
|
|
|
gint position);
|
2018-02-05 19:13:20 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2011-08-15 23:24:59 +00:00
|
|
|
|
void gtk_assistant_remove_page (GtkAssistant *assistant,
|
2011-07-12 01:46:38 +00:00
|
|
|
|
gint page_num);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
void gtk_assistant_set_forward_page_func (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
GtkAssistantPageFunc page_func,
|
|
|
|
|
gpointer data,
|
|
|
|
|
GDestroyNotify destroy);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
void gtk_assistant_set_page_type (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
GtkWidget *page,
|
|
|
|
|
GtkAssistantPageType type);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
GtkAssistantPageType gtk_assistant_get_page_type (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
GtkWidget *page);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
void gtk_assistant_set_page_title (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
GtkWidget *page,
|
|
|
|
|
const gchar *title);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2011-06-06 18:13:44 +00:00
|
|
|
|
const gchar * gtk_assistant_get_page_title (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
GtkWidget *page);
|
|
|
|
|
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
void gtk_assistant_set_page_complete (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
GtkWidget *page,
|
|
|
|
|
gboolean complete);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
gboolean gtk_assistant_get_page_complete (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
GtkWidget *page);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
void gtk_assistant_add_action_widget (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
GtkWidget *child);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-19 13:38:50 +00:00
|
|
|
|
void gtk_assistant_remove_action_widget (GtkAssistant *assistant,
|
2011-04-17 00:45:26 +00:00
|
|
|
|
GtkWidget *child);
|
2006-01-19 13:38:50 +00:00
|
|
|
|
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2006-01-31 16:57:18 +00:00
|
|
|
|
void gtk_assistant_update_buttons_state (GtkAssistant *assistant);
|
2013-03-20 22:17:32 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2010-06-02 20:00:16 +00:00
|
|
|
|
void gtk_assistant_commit (GtkAssistant *assistant);
|
2006-01-31 16:57:18 +00:00
|
|
|
|
|
2018-02-05 19:13:20 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2015-06-15 01:29:09 +00:00
|
|
|
|
void gtk_assistant_set_page_has_padding (GtkAssistant *assistant,
|
|
|
|
|
GtkWidget *page,
|
|
|
|
|
gboolean has_padding);
|
2018-02-05 19:13:20 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
2015-06-15 01:29:09 +00:00
|
|
|
|
gboolean gtk_assistant_get_page_has_padding (GtkAssistant *assistant,
|
|
|
|
|
GtkWidget *page);
|
2019-02-07 20:18:49 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
|
|
|
|
GtkAssistantPage * gtk_assistant_get_page (GtkAssistant *assistant,
|
|
|
|
|
GtkWidget *child);
|
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
|
|
|
|
GtkWidget * gtk_assistant_page_get_child (GtkAssistantPage *page);
|
|
|
|
|
|
2019-02-13 23:27:25 +00:00
|
|
|
|
GDK_AVAILABLE_IN_ALL
|
|
|
|
|
GListModel * gtk_assistant_get_pages (GtkAssistant *assistant);
|
2015-06-15 01:29:09 +00:00
|
|
|
|
|
2006-01-19 13:38:50 +00:00
|
|
|
|
G_END_DECLS
|
|
|
|
|
|
|
|
|
|
#endif /* __GTK_ASSISTANT_H__ */
|