1 /* GTK - The GIMP Toolkit
2 * gtkrecentchooserwidget.c: embeddable recently used resources chooser widget
3 * Copyright (C) 2006 Emmanuele Bassi
5 * This library is free software; you can redistribute it and/or
6 * modify it under the terms of the GNU Lesser General Public
7 * License as published by the Free Software Foundation; either
8 * version 2 of the License, or (at your option) any later version.
10 * This library is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
13 * Lesser General Public License for more details.
15 * You should have received a copy of the GNU Lesser General Public
16 * License along with this library; if not, write to the
17 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
18 * Boston, MA 02111-1307, USA.
23 #include "gtkrecentchooserwidget.h"
24 #include "gtkrecentchooserdefault.h"
25 #include "gtkrecentchooserutils.h"
26 #include "gtkorientable.h"
27 #include "gtktypebuiltins.h"
30 * SECTION:gtkrecentchooserwidget
31 * @Short_description: Displays recently used files
32 * @Title: GtkRecentChooserWidget
33 * @See_also:#GtkRecentChooser, #GtkRecentChooserDialog
35 * #GtkRecentChooserWidget is a widget suitable for selecting recently used
36 * files. It is the main building block of a #GtkRecentChooserDialog. Most
37 * applications will only need to use the latter; you can use
38 * #GtkRecentChooserWidget as part of a larger window if you have special needs.
40 * Note that #GtkRecentChooserWidget does not have any methods of its own.
41 * Instead, you should use the functions that work on a #GtkRecentChooser.
43 * Recently used files are supported since GTK+ 2.10.
47 struct _GtkRecentChooserWidgetPrivate
49 GtkRecentManager *manager;
54 #define GTK_RECENT_CHOOSER_WIDGET_GET_PRIVATE(obj) (GTK_RECENT_CHOOSER_WIDGET (obj)->priv)
56 static GObject *gtk_recent_chooser_widget_constructor (GType type,
58 GObjectConstructParam *params);
59 static void gtk_recent_chooser_widget_set_property (GObject *object,
63 static void gtk_recent_chooser_widget_get_property (GObject *object,
67 static void gtk_recent_chooser_widget_finalize (GObject *object);
70 G_DEFINE_TYPE_WITH_CODE (GtkRecentChooserWidget,
71 gtk_recent_chooser_widget,
73 G_IMPLEMENT_INTERFACE (GTK_TYPE_RECENT_CHOOSER,
74 _gtk_recent_chooser_delegate_iface_init))
77 gtk_recent_chooser_widget_class_init (GtkRecentChooserWidgetClass *klass)
79 GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
81 gobject_class->constructor = gtk_recent_chooser_widget_constructor;
82 gobject_class->set_property = gtk_recent_chooser_widget_set_property;
83 gobject_class->get_property = gtk_recent_chooser_widget_get_property;
84 gobject_class->finalize = gtk_recent_chooser_widget_finalize;
86 _gtk_recent_chooser_install_properties (gobject_class);
88 g_type_class_add_private (klass, sizeof (GtkRecentChooserWidgetPrivate));
93 gtk_recent_chooser_widget_init (GtkRecentChooserWidget *widget)
95 widget->priv = G_TYPE_INSTANCE_GET_PRIVATE (widget, GTK_TYPE_RECENT_CHOOSER_WIDGET,
96 GtkRecentChooserWidgetPrivate);
98 gtk_orientable_set_orientation (GTK_ORIENTABLE (widget),
99 GTK_ORIENTATION_VERTICAL);
103 gtk_recent_chooser_widget_constructor (GType type,
105 GObjectConstructParam *params)
108 GtkRecentChooserWidgetPrivate *priv;
110 object = G_OBJECT_CLASS (gtk_recent_chooser_widget_parent_class)->constructor (type,
114 priv = GTK_RECENT_CHOOSER_WIDGET_GET_PRIVATE (object);
115 priv->chooser = _gtk_recent_chooser_default_new (priv->manager);
118 gtk_container_add (GTK_CONTAINER (object), priv->chooser);
119 gtk_widget_show (priv->chooser);
120 _gtk_recent_chooser_set_delegate (GTK_RECENT_CHOOSER (object),
121 GTK_RECENT_CHOOSER (priv->chooser));
127 gtk_recent_chooser_widget_set_property (GObject *object,
132 GtkRecentChooserWidgetPrivate *priv;
134 priv = GTK_RECENT_CHOOSER_WIDGET_GET_PRIVATE (object);
138 case GTK_RECENT_CHOOSER_PROP_RECENT_MANAGER:
139 priv->manager = g_value_get_object (value);
142 g_object_set_property (G_OBJECT (priv->chooser), pspec->name, value);
148 gtk_recent_chooser_widget_get_property (GObject *object,
153 GtkRecentChooserWidgetPrivate *priv;
155 priv = GTK_RECENT_CHOOSER_WIDGET_GET_PRIVATE (object);
157 g_object_get_property (G_OBJECT (priv->chooser), pspec->name, value);
161 gtk_recent_chooser_widget_finalize (GObject *object)
163 GtkRecentChooserWidgetPrivate *priv;
165 priv = GTK_RECENT_CHOOSER_WIDGET_GET_PRIVATE (object);
166 priv->manager = NULL;
168 G_OBJECT_CLASS (gtk_recent_chooser_widget_parent_class)->finalize (object);
176 * gtk_recent_chooser_widget_new:
178 * Creates a new #GtkRecentChooserWidget object. This is an embeddable widget
179 * used to access the recently used resources list.
181 * Return value: a new #GtkRecentChooserWidget
186 gtk_recent_chooser_widget_new (void)
188 return g_object_new (GTK_TYPE_RECENT_CHOOSER_WIDGET, NULL);
192 * gtk_recent_chooser_widget_new_for_manager:
193 * @manager: a #GtkRecentManager
195 * Creates a new #GtkRecentChooserWidget with a specified recent manager.
197 * This is useful if you have implemented your own recent manager, or if you
198 * have a customized instance of a #GtkRecentManager object.
200 * Return value: a new #GtkRecentChooserWidget
205 gtk_recent_chooser_widget_new_for_manager (GtkRecentManager *manager)
207 g_return_val_if_fail (manager == NULL || GTK_IS_RECENT_MANAGER (manager), NULL);
209 return g_object_new (GTK_TYPE_RECENT_CHOOSER_WIDGET,
210 "recent-manager", manager,