1 /*
2  * This file is part of d-dazzle.
3  *
4  * d-dazzle is free software; you can redistribute it and/or modify
5  * it under the terms of the GNU Lesser General Public License
6  * as published by the Free Software Foundation; either version 3
7  * of the License, or (at your option) any later version, with
8  * some exceptions, please read the COPYING file.
9  *
10  * d-dazzle 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
13  * GNU Lesser General Public License for more details.
14  *
15  * You should have received a copy of the GNU Lesser General Public License
16  * along with d-dazzle; if not, write to the Free Software
17  * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110, USA
18  */
19 module dazzle.ShortcutsWindow;
20 
21 private import dazzle.c.functions;
22 public  import dazzle.c.types;
23 private import gobject.Signals;
24 private import gtk.BuildableIF;
25 private import gtk.BuildableT;
26 private import gtk.Window;
27 private import std.algorithm;
28 
29 
30 /** */
31 public class ShortcutsWindow : Window
32 {
33 	/** the main Gtk struct */
34 	protected DzlShortcutsWindow* dzlShortcutsWindow;
35 
36 	/** Get the main Gtk struct */
37 	public DzlShortcutsWindow* getShortcutsWindowStruct(bool transferOwnership = false)
38 	{
39 		if (transferOwnership)
40 			ownedRef = false;
41 		return dzlShortcutsWindow;
42 	}
43 
44 	/** the main Gtk struct as a void* */
45 	protected override void* getStruct()
46 	{
47 		return cast(void*)dzlShortcutsWindow;
48 	}
49 
50 	/**
51 	 * Sets our main struct and passes it to the parent class.
52 	 */
53 	public this (DzlShortcutsWindow* dzlShortcutsWindow, bool ownedRef = false)
54 	{
55 		this.dzlShortcutsWindow = dzlShortcutsWindow;
56 		super(cast(GtkWindow*)dzlShortcutsWindow, ownedRef);
57 	}
58 
59 
60 	/** */
61 	public static GType getType()
62 	{
63 		return dzl_shortcuts_window_get_type();
64 	}
65 
66 	/**
67 	 * The ::close signal is a
68 	 * [keybinding signal][GtkBindingSignal]
69 	 * which gets emitted when the user uses a keybinding to close
70 	 * the window.
71 	 *
72 	 * The default binding for this signal is the Escape key.
73 	 */
74 	gulong addOnClose(void delegate(ShortcutsWindow) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0)
75 	{
76 		return Signals.connect(this, "close", dlg, connectFlags ^ ConnectFlags.SWAPPED);
77 	}
78 
79 	/**
80 	 * The ::search signal is a
81 	 * [keybinding signal][GtkBindingSignal]
82 	 * which gets emitted when the user uses a keybinding to start a search.
83 	 *
84 	 * The default binding for this signal is Control-F.
85 	 */
86 	gulong addOnSearch(void delegate(ShortcutsWindow) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0)
87 	{
88 		return Signals.connect(this, "search", dlg, connectFlags ^ ConnectFlags.SWAPPED);
89 	}
90 }