Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/Remmina/Remmina.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorbhatman1441 <blackhat1441@protonmail.com>2023-08-11 20:01:25 +0300
committerbhatman1441 <blackhat1441@protonmail.com>2023-08-11 20:01:25 +0300
commit9e2bd959c6f40f364635ee3e726f3e3641dee0a7 (patch)
tree062a3b5163ac01f083e08ae4b528268aac08142b /src
parent12777701281ec07f2aefa46fb55637ad2844209b (diff)
parent5c11e8f181d03819643dfdc6e0035cd8fa72e218 (diff)
Merge branch 'host-key-combo' into 'master'
New feature: Allow user to specify use of modifiers when changing key preferences See merge request Remmina/Remmina!2523
Diffstat (limited to 'src')
-rw-r--r--src/remmina_key_chooser.c14
1 files changed, 14 insertions, 0 deletions
diff --git a/src/remmina_key_chooser.c b/src/remmina_key_chooser.c
index 876eb9d84..69a87c75b 100644
--- a/src/remmina_key_chooser.c
+++ b/src/remmina_key_chooser.c
@@ -52,6 +52,14 @@ static gboolean remmina_key_chooser_dialog_on_key_press(GtkWidget *widget, GdkEv
return TRUE;
}
+/* User option to use key modifiers when selecting keyboard shortcuts */
+void remmina_key_chooser_dialog_set_option_modifier(GtkWidget *widget, gboolean state, RemminaKeyChooserArguments *arguments)
+{
+ TRACE_CALL(__func__);
+ gtk_switch_set_state(GTK_SWITCH(widget), state);
+ arguments->use_modifiers = state;
+}
+
/* Show a key chooser dialog and return the keyval for the selected key */
RemminaKeyChooserArguments* remmina_key_chooser_new(GtkWindow *parent_window, gboolean use_modifiers)
{
@@ -66,9 +74,15 @@ RemminaKeyChooserArguments* remmina_key_chooser_new(GtkWindow *parent_window, gb
/* Setup the dialog */
dialog = GTK_DIALOG(gtk_builder_get_object(builder, "KeyChooserDialog"));
gtk_window_set_transient_for(GTK_WINDOW(dialog), parent_window);
+
+ /* Connect the key modifier switch signal */
+ g_signal_connect(gtk_builder_get_object(builder, "switch_option_key_modifier"), "state-set",
+ G_CALLBACK(remmina_key_chooser_dialog_set_option_modifier), arguments);
+
/* Connect the GtkEventBox signal */
g_signal_connect(gtk_builder_get_object(builder, "eventbox_key_chooser"), "key-press-event",
G_CALLBACK(remmina_key_chooser_dialog_on_key_press), arguments);
+
/* Show the dialog and destroy it after the use */
arguments->response = gtk_dialog_run(dialog);
gtk_widget_destroy(GTK_WIDGET(dialog));