Add hidebar keybind
This commit is contained in:
parent
3325e17195
commit
d97045bf47
49
config.def.h
49
config.def.h
|
@ -14,11 +14,14 @@
|
|||
|
||||
/* See more:
|
||||
* https://webkitgtk.org/reference/webkit2gtk/stable/class.Settings.html */
|
||||
#define WEBKIT \
|
||||
"enable-back-forward-navigation-gestures", true, "enable-developer-extras", true, \
|
||||
"enable-smooth-scrolling", false
|
||||
#define WEBKIT \
|
||||
"enable-back-forward-navigation-gestures", true, \
|
||||
"enable-developer-extras", true, \
|
||||
"enable-smooth-scrolling", false
|
||||
|
||||
#define GTK "gtk-application-prefer-dark-theme", true, "gtk-enable-animations", false
|
||||
#define GTK \
|
||||
"gtk-application-prefer-dark-theme", true, \
|
||||
"gtk-enable-animations", false
|
||||
|
||||
#define HOME "https://lite.duckduckgo.com/html/"
|
||||
#define SEARCH "https://lite.duckduckgo.com/html/?q=%s"
|
||||
|
@ -48,7 +51,8 @@ typedef enum {
|
|||
show_finder,
|
||||
finder_next,
|
||||
finder_prev,
|
||||
newtab
|
||||
newtab,
|
||||
hidebar
|
||||
} func;
|
||||
|
||||
#define SFT 1 << 0
|
||||
|
@ -60,23 +64,24 @@ static struct {
|
|||
unsigned key;
|
||||
func id;
|
||||
} keys[] = {
|
||||
{ CTRL, KEY(h), goback },
|
||||
{ CTRL, KEY(l), goforward },
|
||||
{ CTRL, KEY(r), refresh },
|
||||
{ CTRL | SFT, KEY(R), refresh_force },
|
||||
{ CTRL | SFT, KEY(H), back_to_home },
|
||||
{ CTRL, KEY(equal), zoomin },
|
||||
{ CTRL, KEY(minus), zoomout },
|
||||
{ CTRL, KEY(0), zoom_reset },
|
||||
{ ALT, KEY(h), prev_tab },
|
||||
{ ALT, KEY(l), next_tab },
|
||||
{ CTRL, KEY(w), close_tab },
|
||||
{ 0x0, KEY(F11), toggle_fullscreen },
|
||||
{ CTRL, KEY(e), show_searchbar },
|
||||
{ CTRL, KEY(f), show_finder },
|
||||
{ CTRL, KEY(n), finder_next },
|
||||
{ CTRL | SFT, KEY(N), finder_prev },
|
||||
{ CTRL, KEY(t), newtab }
|
||||
{ CTRL, KEY(h), goback },
|
||||
{ CTRL, KEY(l), goforward },
|
||||
{ CTRL, KEY(r), refresh },
|
||||
{ CTRL | SFT, KEY(R), refresh_force },
|
||||
{ CTRL | SFT, KEY(H), back_to_home },
|
||||
{ CTRL, KEY(equal), zoomin },
|
||||
{ CTRL, KEY(minus), zoomout },
|
||||
{ CTRL, KEY(0), zoom_reset },
|
||||
{ ALT, KEY(h), prev_tab },
|
||||
{ ALT, KEY(l), next_tab },
|
||||
{ CTRL, KEY(w), close_tab },
|
||||
{ 0x0, KEY(F11), toggle_fullscreen },
|
||||
{ CTRL, KEY(e), show_searchbar },
|
||||
{ CTRL, KEY(f), show_finder },
|
||||
{ CTRL, KEY(n), finder_next },
|
||||
{ CTRL | SFT, KEY(N), finder_prev },
|
||||
{ CTRL, KEY(t), newtab },
|
||||
{ 0x0, KEY(Escape), hidebar }
|
||||
};
|
||||
/* For controls more akin to normal browsers, use:
|
||||
{
|
||||
|
|
22
rose.c
22
rose.c
|
@ -6,8 +6,6 @@
|
|||
* files to modify, copy, merge, publish, distribute and/or
|
||||
* sublicense copies of this sotware for their own use.
|
||||
* This code does not come with any warranty.
|
||||
*
|
||||
* @author: fenze <contact@fenze.dev>
|
||||
*/
|
||||
#include <string.h>
|
||||
#include <stdbool.h>
|
||||
|
@ -28,7 +26,7 @@
|
|||
"offline-application-cache-directory", CACHE_DIR, \
|
||||
"service-worker-registrations-directory", CACHE_DIR
|
||||
|
||||
enum { _SEARCH, _FIND };
|
||||
enum { _SEARCH, _FIND, _HIDDEN };
|
||||
|
||||
static int entry_mode;
|
||||
static GtkWindow *window;
|
||||
|
@ -86,7 +84,8 @@ void redirect_if_annoying(WebKitWebView *view, const char *uri){
|
|||
str_init(uri_filtered, l);
|
||||
|
||||
int check = libre_redirect(uri, uri_filtered);
|
||||
if(check == 2){
|
||||
|
||||
if (check == 2){
|
||||
webkit_web_view_load_uri(view, uri_filtered);
|
||||
}
|
||||
|
||||
|
@ -153,12 +152,15 @@ void show_bar(GtkNotebook *notebook)
|
|||
gtk_entry_buffer_set_text(search_buf, url, strlen(url));
|
||||
gtk_widget_show(GTK_WIDGET(bar));
|
||||
gtk_window_set_focus(window, GTK_WIDGET(search));
|
||||
} else if (entry_mode == _HIDDEN) {
|
||||
gtk_widget_hide(GTK_WIDGET(bar));
|
||||
} else {
|
||||
const char *search_text = webkit_find_controller_get_search_text(
|
||||
webkit_web_view_get_find_controller(notebook_get_webview(notebook)));
|
||||
|
||||
if (search_text != NULL)
|
||||
gtk_entry_buffer_set_text(search_buf, search_text, strlen(search_text));
|
||||
|
||||
gtk_entry_set_placeholder_text(search, "Find");
|
||||
gtk_widget_show(GTK_WIDGET(bar));
|
||||
gtk_window_set_focus(window, GTK_WIDGET(search));
|
||||
|
@ -267,9 +269,11 @@ int handle_key(func id, GtkNotebook *notebook)
|
|||
case newtab:
|
||||
notebook_append(notebook, NULL);
|
||||
gtk_notebook_set_show_tabs(notebook, true);
|
||||
|
||||
case hidebar:
|
||||
entry_mode = _HIDDEN;
|
||||
show_bar(notebook);
|
||||
}
|
||||
|
||||
|
||||
return 1;
|
||||
}
|
||||
|
||||
|
@ -301,17 +305,14 @@ void search_activate(GtkEntry *self, GtkNotebook *notebook)
|
|||
void window_init(GtkNotebook *notebook)
|
||||
{
|
||||
GtkCssProvider *css = gtk_css_provider_new();
|
||||
|
||||
gtk_css_provider_load_from_path(css, "/usr/share/themes/rose/style.css", NULL);
|
||||
gtk_style_context_add_provider_for_screen(gdk_screen_get_default(), GTK_STYLE_PROVIDER(css),
|
||||
800);
|
||||
|
||||
gtk_entry_buffer_new("", 0);
|
||||
gtk_entry_set_alignment(search, 0.48);
|
||||
gtk_widget_set_size_request(GTK_WIDGET(search), 300, -1);
|
||||
gtk_header_bar_set_custom_title(bar, GTK_WIDGET(search));
|
||||
gtk_window_set_titlebar(window, GTK_WIDGET(bar));
|
||||
|
||||
g_signal_connect(search, "activate", G_CALLBACK(search_activate), notebook);
|
||||
g_signal_connect(window, "key-press-event", G_CALLBACK(keypress), notebook);
|
||||
g_signal_connect(window, "destroy", G_CALLBACK(exit), notebook);
|
||||
|
@ -340,8 +341,7 @@ void setup(GtkNotebook *notebook, const char *uri)
|
|||
gtk_container_add(GTK_CONTAINER(window), GTK_WIDGET(notebook));
|
||||
gtk_widget_show_all(GTK_WIDGET(window));
|
||||
gtk_widget_hide(GTK_WIDGET(bar));
|
||||
webkit_web_view_set_zoom_level(notebook_get_webview(notebook), ZOOM);
|
||||
|
||||
webkit_web_view_set_zoom_level(notebook_get_webview(notebook), ZOOM);
|
||||
}
|
||||
|
||||
int main(int argc, char **argv)
|
||||
|
|
Loading…
Reference in New Issue
Block a user