Aditional remote command - window list
[geeqie.git] / src / ui-utildlg.h
1 /*
2  * Copyright (C) 2004 John Ellis
3  * Copyright (C) 2008 - 2016 The Geeqie Team
4  *
5  * Author: John Ellis
6  *
7  * This program is free software; you can redistribute it and/or modify
8  * it under the terms of the GNU General Public License as published by
9  * the Free Software Foundation; either version 2 of the License, or
10  * (at your option) any later version.
11  *
12  * This program is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
15  * GNU General Public License for more details.
16  *
17  * You should have received a copy of the GNU General Public License along
18  * with this program; if not, write to the Free Software Foundation, Inc.,
19  * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20  */
21
22 #ifndef UI_UTILDLG_H
23 #define UI_UTILDLG_H
24
25 #include <glib.h>
26 #include <gtk/gtk.h>
27
28 struct FileData;
29
30 struct GenericDialog
31 {
32         GtkWidget *dialog;      /**< window */
33         GtkWidget *vbox;        /**< place to add widgets */
34
35         GtkWidget *hbox;        /**< button hbox */
36
37         gboolean auto_close;
38
39         void (*default_cb)(GenericDialog *, gpointer);
40         void (*cancel_cb)(GenericDialog *, gpointer);
41         gpointer data;
42
43         GtkWidget *cancel_button; /**< private */
44
45 };
46
47 #define GENERIC_DIALOG(gd) ((GenericDialog *)gd)
48
49 struct FileDialog
50 {
51         GenericDialog gd;
52
53         GtkWidget *entry;
54
55         gint type;
56
57         FileData *source_fd;
58         GList *source_list;
59
60         gchar *dest_path;
61 };
62
63
64 /**
65  * @headerfile generic_dialog_new
66  * When parent is not NULL, the dialog is set as a transient of the window containing parent
67  */
68 GenericDialog *generic_dialog_new(const gchar *title,
69                                   const gchar *role,
70                                   GtkWidget *parent, gboolean auto_close,
71                                   void (*cancel_cb)(GenericDialog *, gpointer), gpointer data);
72 void generic_dialog_close(GenericDialog *gd);
73
74 GtkWidget *generic_dialog_add_button(GenericDialog *gd, const gchar *icon_name, const gchar *text,
75                                      void (*func_cb)(GenericDialog *, gpointer), gboolean is_default);
76 void generic_dialog_attach_default(GenericDialog *gd, GtkWidget *widget);
77
78 GtkWidget *generic_dialog_add_message(GenericDialog *gd, const gchar *icon_name,
79                                       const gchar *heading, const gchar *text, gboolean expand);
80
81 gboolean generic_dialog_get_alternative_button_order(GtkWidget *widget);
82
83 GenericDialog *warning_dialog(const gchar *heading, const gchar *text,
84                               const gchar *icon_name, GtkWidget *parent);
85
86 FileDialog *file_dialog_new(const gchar *title,
87                             const gchar *role,
88                             GtkWidget *parent,
89                             void (*cancel_cb)(FileDialog *, gpointer), gpointer data);
90 void file_dialog_close(FileDialog *fd);
91
92 GtkWidget *file_dialog_add_button(FileDialog *fd, const gchar *stock_id, const gchar *text,
93                                   void (*func_cb)(FileDialog *, gpointer), gboolean is_default);
94
95 /**
96  * @headerfile file_dialog_add_path_widgets
97  * default_path is default base directory, and is only used if no history
98  * exists for history_key (HOME is used if default_path is NULL).
99  * path can be a full path or only a file name. If name only, appended to
100  * the default_path or the last history (see default_path)
101  */
102 void file_dialog_add_path_widgets(FileDialog *fd, const gchar *default_path, const gchar *path,
103                                   const gchar *history_key, const gchar *filter, const gchar *filter_desc);
104
105 void file_dialog_clear_filter(FileDialog *fd);
106 void file_dialog_sync_history(FileDialog *fd, gboolean dir_only);
107
108 void generic_dialog_windows_load_config(const gchar **attribute_names, const gchar **attribute_values);
109 void generic_dialog_windows_write_config(GString *outstr, gint indent);
110
111 void appimage_notification();
112 #endif
113 /* vim: set shiftwidth=8 softtabstop=0 cindent cinoptions={1s: */