GtkFileChooserNativeQuartz: add partial support for extra widget

When the extra widget is a GtkLabel, then its text will be displayed as
a message in the NSSavePanel or NSOpenPanel

https://bugzilla.gnome.org/show_bug.cgi?id=784723
This commit is contained in:
Tom Schoonjans 2017-07-04 08:07:09 +01:00 committed by Matthias Clasen
parent 44e90c4dd3
commit 55d139bc46

View File

@ -61,6 +61,7 @@ typedef struct {
char *accept_label; char *accept_label;
char *cancel_label; char *cancel_label;
char *title; char *title;
char *message;
GSList *shortcut_uris; GSList *shortcut_uris;
@ -165,6 +166,7 @@ filechooser_quartz_data_free (FileChooserQuartzData *data)
g_free (data->accept_label); g_free (data->accept_label);
g_free (data->cancel_label); g_free (data->cancel_label);
g_free (data->title); g_free (data->title);
g_free (data->message);
g_free (data); g_free (data);
} }
@ -242,6 +244,9 @@ filechooser_quartz_launch (FileChooserQuartzData *data)
if (data->title) if (data->title)
[data->panel setTitle:[NSString stringWithUTF8String:data->title]]; [data->panel setTitle:[NSString stringWithUTF8String:data->title]];
if (data->message)
[data->panel setMessage:[NSString stringWithUTF8String:data->message]];
if (data->current_file) if (data->current_file)
{ {
GFile *folder; GFile *folder;
@ -347,9 +352,18 @@ gtk_file_chooser_native_quartz_show (GtkFileChooserNative *self)
guint update_preview_signal; guint update_preview_signal;
GSList *filters, *l; GSList *filters, *l;
int n_filters, i; int n_filters, i;
GtkWidget *extra_widget = NULL;
char *message = NULL;
if (gtk_file_chooser_get_extra_widget (GTK_FILE_CHOOSER (self)) != NULL) extra_widget = gtk_file_chooser_get_extra_widget (GTK_FILE_CHOOSER (self));
// if the extra_widget is a GtkLabel, then use its text to set the dialog message
if (extra_widget != NULL)
{
if (!GTK_IS_LABEL (extra_widget))
return FALSE; return FALSE;
else
message = g_strdup (gtk_label_get_text (GTK_LABEL (extra_widget)));
}
update_preview_signal = g_signal_lookup ("update-preview", GTK_TYPE_FILE_CHOOSER); update_preview_signal = g_signal_lookup ("update-preview", GTK_TYPE_FILE_CHOOSER);
if (g_signal_has_handler_pending (self, update_preview_signal, 0, TRUE)) if (g_signal_has_handler_pending (self, update_preview_signal, 0, TRUE))
@ -407,6 +421,8 @@ gtk_file_chooser_native_quartz_show (GtkFileChooserNative *self)
data->title = data->title =
g_strdup (gtk_native_dialog_get_title (GTK_NATIVE_DIALOG (self))); g_strdup (gtk_native_dialog_get_title (GTK_NATIVE_DIALOG (self)));
data->message = message;
if (self->current_file) if (self->current_file)
data->current_file = g_object_ref (self->current_file); data->current_file = g_object_ref (self->current_file);
else else