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.ShortcutThemeEditor; 20 21 private import dazzle.ShortcutTheme; 22 private import dazzle.c.functions; 23 public import dazzle.c.types; 24 private import glib.ConstructionException; 25 private import gobject.ObjectG; 26 private import gobject.Signals; 27 private import gtk.Bin; 28 private import gtk.BuildableIF; 29 private import gtk.BuildableT; 30 private import gtk.Widget; 31 private import std.algorithm; 32 33 34 /** */ 35 public class ShortcutThemeEditor : Bin 36 { 37 /** the main Gtk struct */ 38 protected DzlShortcutThemeEditor* dzlShortcutThemeEditor; 39 40 /** Get the main Gtk struct */ 41 public DzlShortcutThemeEditor* getShortcutThemeEditorStruct(bool transferOwnership = false) 42 { 43 if (transferOwnership) 44 ownedRef = false; 45 return dzlShortcutThemeEditor; 46 } 47 48 /** the main Gtk struct as a void* */ 49 protected override void* getStruct() 50 { 51 return cast(void*)dzlShortcutThemeEditor; 52 } 53 54 /** 55 * Sets our main struct and passes it to the parent class. 56 */ 57 public this (DzlShortcutThemeEditor* dzlShortcutThemeEditor, bool ownedRef = false) 58 { 59 this.dzlShortcutThemeEditor = dzlShortcutThemeEditor; 60 super(cast(GtkBin*)dzlShortcutThemeEditor, ownedRef); 61 } 62 63 64 /** */ 65 public static GType getType() 66 { 67 return dzl_shortcut_theme_editor_get_type(); 68 } 69 70 /** */ 71 public this() 72 { 73 auto p = dzl_shortcut_theme_editor_new(); 74 75 if(p is null) 76 { 77 throw new ConstructionException("null returned by new"); 78 } 79 80 this(cast(DzlShortcutThemeEditor*) p); 81 } 82 83 /** 84 * Gets the shortcut theme if one hsa been set. 85 * 86 * Returns: An #DzlShortcutTheme or %NULL 87 */ 88 public ShortcutTheme getTheme() 89 { 90 auto p = dzl_shortcut_theme_editor_get_theme(dzlShortcutThemeEditor); 91 92 if(p is null) 93 { 94 return null; 95 } 96 97 return ObjectG.getDObject!(ShortcutTheme)(cast(DzlShortcutTheme*) p); 98 } 99 100 /** */ 101 public void setTheme(ShortcutTheme theme) 102 { 103 dzl_shortcut_theme_editor_set_theme(dzlShortcutThemeEditor, (theme is null) ? null : theme.getShortcutThemeStruct()); 104 } 105 106 /** 107 * The "changed" signal is emitted when one of the rows within the editor 108 * has been changed. 109 * 110 * You might want to use this signal to save your theme changes to your 111 * configured storage backend. 112 */ 113 gulong addOnChanged(void delegate(ShortcutThemeEditor) dlg, ConnectFlags connectFlags=cast(ConnectFlags)0) 114 { 115 return Signals.connect(this, "changed", dlg, connectFlags ^ ConnectFlags.SWAPPED); 116 } 117 }