aboutsummaryrefslogtreecommitdiff
path: root/lib/Arctica/Browser/Overlay
diff options
context:
space:
mode:
authorGZNGET FOSS Team <opensource@gznianguan.com>2017-06-22 22:43:11 +0200
committerMike Gabriel <mike.gabriel@das-netzwerkteam.de>2017-06-22 23:18:45 +0200
commit985c827c92ebeb19487ab62970324242106179ed (patch)
tree04036c289f31833f66bf0e8320e261577ab002da /lib/Arctica/Browser/Overlay
downloadarctica-browser-985c827c92ebeb19487ab62970324242106179ed.tar.gz
arctica-browser-985c827c92ebeb19487ab62970324242106179ed.tar.bz2
arctica-browser-985c827c92ebeb19487ab62970324242106179ed.zip
initial commit, development state dating 20170619.
Diffstat (limited to 'lib/Arctica/Browser/Overlay')
-rw-r--r--lib/Arctica/Browser/Overlay/Proxy.pm103
-rw-r--r--lib/Arctica/Browser/Overlay/ToolBar.pm229
-rw-r--r--lib/Arctica/Browser/Overlay/Version.pm65
-rw-r--r--lib/Arctica/Browser/Overlay/WebView.pm184
4 files changed, 581 insertions, 0 deletions
diff --git a/lib/Arctica/Browser/Overlay/Proxy.pm b/lib/Arctica/Browser/Overlay/Proxy.pm
new file mode 100644
index 0000000..932c022
--- /dev/null
+++ b/lib/Arctica/Browser/Overlay/Proxy.pm
@@ -0,0 +1,103 @@
+################################################################################
+# _____ _
+# |_ _| |_ ___
+# | | | ' \/ -_)
+# |_| |_||_\___|
+# _ _ ____ _ _
+# / \ _ __ ___| |_(_) ___ __ _ | _ \ _ __ ___ (_) ___ ___| |_
+# / _ \ | '__/ __| __| |/ __/ _` | | |_) | '__/ _ \| |/ _ \/ __| __|
+# / ___ \| | | (__| |_| | (_| (_| | | __/| | | (_) | | __/ (__| |_
+# /_/ \_\_| \___|\__|_|\___\__,_| |_| |_| \___// |\___|\___|\__|
+# |__/
+# The Arctica Modular Remote Computing Framework
+#
+################################################################################
+#
+# Copyright (C) 2015-2016 The Arctica Project
+# http://http://arctica-project.org/
+#
+# This code is dual licensed: strictly GPL-2 or AGPL-3+
+#
+# GPL-2
+# -----
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; version 2 of the License.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the
+# Free Software Foundation, Inc.,
+#
+# 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# AGPL-3+
+# -------
+# This programm is free software; you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# This programm is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program; if not, write to the
+# Free Software Foundation, Inc.,
+# 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# Copyright (C) 2015-2016 Guangzhou Nianguan Electronics Technology Co.Ltd.
+# <opensource@gznianguan.com>
+# Copyright (C) 2015-2016 Mike Gabriel <mike.gabriel@das-netzwerkteam.de>
+#
+################################################################################
+package Arctica::Browser::Overlay::Proxy;
+use strict;
+use Glib 'TRUE', 'FALSE';
+# Be very selective about what (if any) gets exported by default:
+our @EXPORT = qw();
+# And be mindful of what we let the caller request, too:
+our @EXPORT_OK = qw( );
+
+sub new {
+ my $class_name = $_[0];
+# $arctica_core_object = $_[1];
+ my $self = {
+ isArctica => 1,
+ aobject_name => "browser_proxy",
+ webview => FALSE,
+ };
+ bless($self, $class_name);
+
+ $self->_set_proxy(8888);
+
+ return $self;
+}
+
+sub _set_proxy {
+ my $self = $_[0];
+ my $port = $_[1];
+ my $username = $_[2];
+ my $password = $_[3];
+ my $hostname = "localhost";
+ my $auth_string;
+ if ($username and $password) {
+ $auth_string = "$username:$password\@";
+ }
+ my $proxy_string = "http://$auth_string$hostname:$port";
+ $ENV{'HTTP_PROXY'} = $proxy_string;
+ $ENV{'http_proxy'} = $proxy_string;
+ $ENV{'HTTPS_PROXY'} = $proxy_string;
+ $ENV{'https_proxy'} = $proxy_string;
+
+}
+
+
+
+1;
diff --git a/lib/Arctica/Browser/Overlay/ToolBar.pm b/lib/Arctica/Browser/Overlay/ToolBar.pm
new file mode 100644
index 0000000..751c119
--- /dev/null
+++ b/lib/Arctica/Browser/Overlay/ToolBar.pm
@@ -0,0 +1,229 @@
+################################################################################
+# _____ _
+# |_ _| |_ ___
+# | | | ' \/ -_)
+# |_| |_||_\___|
+# _ _ ____ _ _
+# / \ _ __ ___| |_(_) ___ __ _ | _ \ _ __ ___ (_) ___ ___| |_
+# / _ \ | '__/ __| __| |/ __/ _` | | |_) | '__/ _ \| |/ _ \/ __| __|
+# / ___ \| | | (__| |_| | (_| (_| | | __/| | | (_) | | __/ (__| |_
+# /_/ \_\_| \___|\__|_|\___\__,_| |_| |_| \___// |\___|\___|\__|
+# |__/
+# The Arctica Modular Remote Computing Framework
+#
+################################################################################
+#
+# Copyright (C) 2015-2016 The Arctica Project
+# http://http://arctica-project.org/
+#
+# This code is dual licensed: strictly GPL-2 or AGPL-3+
+#
+# GPL-2
+# -----
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; version 2 of the License.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the
+# Free Software Foundation, Inc.,
+#
+# 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# AGPL-3+
+# -------
+# This programm is free software; you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# This programm is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program; if not, write to the
+# Free Software Foundation, Inc.,
+# 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# Copyright (C) 2015-2016 Guangzhou Nianguan Electronics Technology Co.Ltd.
+# <opensource@gznianguan.com>
+# Copyright (C) 2015-2016 Mike Gabriel <mike.gabriel@das-netzwerkteam.de>
+#
+################################################################################
+package Arctica::Browser::Overlay::ToolBar;
+use strict;
+use Gtk3;
+use Glib 'TRUE', 'FALSE';
+use Data::Dumper;
+# Be very selective about what (if any) gets exported by default:
+our @EXPORT = qw();
+# And be mindful of what we let the caller request, too:
+our @EXPORT_OK = qw( );
+
+sub new {
+ my $class_name = $_[0];
+# $arctica_core_object = $_[1];
+ my $self = {
+ isArctica => 1,
+ aobject_name => "browser_toolbar",
+ webview => FALSE,
+ };
+ bless($self, $class_name);
+
+ $self->_gen_toolbar_main;
+
+ return $self;
+}
+
+
+sub return_toolbar {
+ my $self = $_[0];
+ if ($self->{'_gtk'}{'toolbar'}{'main'}) {
+ return $self->{'_gtk'}{'toolbar'}{'main'};
+ } else {
+ die("Can't return a toolbar that does not exist, can we?");
+ }
+}
+
+sub _gen_toolbar_main {
+ my $self = $_[0];
+ $self->{'_gtk'}{'toolbar'}{'main'} = Gtk3::Toolbar->new;
+ $self->{'_gtk'}{'toolbar'}{'main'}->set_icon_size('small-toolbar');
+ $self->{'_gtk'}{'toolbar'}{'main'}->set_show_arrow(FALSE);
+ $self->{'_gtk'}{'toolbar'}{'main'}->set_orientation('GTK_ORIENTATION_HORIZONTAL');
+
+ $self->_gen_history_buttons($self->{'_gtk'}{'toolbar'}{'main'});
+
+ $self->{'_gtk'}{'toolbar'}{'main'}->insert(Gtk3::SeparatorToolItem->new ,-1 );
+
+ $self->_gen_url_entry_area($self->{'_gtk'}{'toolbar'}{'main'});
+
+ $self->{'_gtk'}{'urlentry'}{'url_entry'}->grab_focus;
+}
+
+sub _gen_url_entry_area {
+ my $self = $_[0];
+ my $the_toolbar = $_[1];
+ $self->{'_gtk'}{'urlentry'}{'containerbox'} = Gtk3::ToolItem->new();
+ $self->{'_gtk'}{'urlentry'}{'containerbox'}->set_expand(1);
+
+ $self->{'_gtk'}{'urlentry'}{'url_entry'} = Gtk3::Entry->new();
+ $self->{'_gtk'}{'urlentry'}{'url_entry'}->signal_connect( "activate" => sub {$self->_sigfunc_url_entry_activate;}, undef );
+ $self->{'_gtk'}{'urlentry'}{'url_entry'}->signal_connect( 'icon-press' => sub {$self->_sigfunc_url_entry_icon_press(@_)} );
+
+ $self->{'_gtk'}{'urlentry'}{'containerbox'}->add($self->{'_gtk'}{'urlentry'}{'url_entry'});
+
+ $the_toolbar->insert($self->{'_gtk'}{'urlentry'}{'containerbox'}, -1);
+}
+
+sub _gen_history_buttons {
+ my $self = $_[0];
+ my $the_toolbar = $_[1];
+ $self->{'_gtk'}{'history'}{'btn_back'} = Gtk3::ToolButton->new_from_stock('gtk-go-back');
+ $self->{'_gtk'}{'history'}{'btn_back'}->signal_connect( "clicked" => sub {$self->_sigfunc_history_back;}, undef );
+ $the_toolbar->insert($self->{'_gtk'}{'history'}{'btn_back'}, -1);
+
+ $self->{'_gtk'}{'history'}{'btn_forward'} = Gtk3::ToolButton->new_from_stock('gtk-go-forward');
+ $self->{'_gtk'}{'history'}{'btn_forward'}->signal_connect( "clicked" => sub {$self->_sigfunc_history_forward;}, undef );
+ $the_toolbar->insert($self->{'_gtk'}{'history'}{'btn_forward'}, -1);
+}
+
+sub ext_sigfunc {
+ my $self = $_[0];
+ my $func = $_[1];
+ my $func_data = $_[2];
+# print "TOOLBAR SIGFUNC:\t$_[1]\n";
+# print Dumper($_[2]);
+ if ($func eq "load_progress") {
+ $self->_url_entry_progress_update($func_data);
+ } elsif ($func eq "load_committed") {
+ $self->_url_entry_status_change($func,$func_data);
+ } elsif ($func eq "load_finished") {
+ $self->_url_entry_status_change($func,$func_data);
+ }
+}
+
+sub _url_entry_status_change {
+ my $self = $_[0];
+ my $state = $_[1];
+ my $uri = $_[2];
+ if ($state eq "load_committed") {
+ $self->{'_gtk'}{'urlentry'}{'_status'} = "committed";
+ $self->{'_gtk'}{'urlentry'}{'url_entry'}->set_text($uri);
+ $self->{'_gtk'}{'urlentry'}{'url_entry'}->set_icon_from_stock('secondary','gtk-stop');
+ } elsif ($state eq "load_finished") {
+ $self->{'_gtk'}{'urlentry'}{'_status'} = "finished";
+ $self->{'_gtk'}{'urlentry'}{'url_entry'}->set_text($uri);
+ $self->{'_gtk'}{'urlentry'}{'url_entry'}->set_icon_from_stock('secondary','gtk-refresh');
+ }
+}
+
+
+sub _url_entry_progress_update {
+ my $self = $_[0];
+ my $load_fraction = $_[1];
+ if ($self->{'_gtk'}{'urlentry'}{'url_entry'}) {
+ if ($load_fraction < 1) {
+ $self->{'_gtk'}{'urlentry'}{'url_entry'}->set_progress_fraction($load_fraction);
+ } else {
+ $self->{'_gtk'}{'urlentry'}{'url_entry'}->set_progress_fraction(0);
+ }
+ }
+}
+
+sub _sigfunc_url_entry_icon_press {
+ my $self = $_[0];
+ my $which_icon = $_[2];
+ if ($which_icon eq "secondary") {
+ if ($self->{'_gtk'}{'urlentry'}{'_status'} eq "commited") {
+ if ($self->{'webview'}) {
+ $self->{'webview'}->ext_sigfunc('stop');
+ }
+ } elsif ($self->{'_gtk'}{'urlentry'}{'_status'} eq "finished") {
+ if ($self->{'webview'}) {
+ $self->{'webview'}->ext_sigfunc('reload');
+ }
+ }
+ }
+}
+
+sub _sigfunc_url_entry_activate {
+ my $self = $_[0];
+ if ($self->{'webview'}) {
+ my $uri = $self->{'_gtk'}{'urlentry'}{'url_entry'}->get_text;
+ unless ($uri =~ /^[a-z]*\:\/\/.*/) {# do better URL validation here!
+ $uri = "http://$uri";
+ }
+ $self->{'webview'}->ext_sigfunc('load_uri',$uri);
+ } else {
+ warn("No WebView attached to this toolbar?");
+ }
+}
+
+sub _sigfunc_history_back {
+ my $self = $_[0];
+ if ($self->{'webview'}) {
+ $self->{'webview'}->ext_sigfunc('history_back');
+ } else {
+ warn("No WebView attached to this toolbar?");
+ }
+}
+
+sub _sigfunc_history_forward {
+ my $self = $_[0];
+ if ($self->{'webview'}) {
+ $self->{'webview'}->ext_sigfunc('history_forward');
+ } else {
+ warn("No WebView attached to this toolbar?");
+ }
+}
+
+
+1;
diff --git a/lib/Arctica/Browser/Overlay/Version.pm b/lib/Arctica/Browser/Overlay/Version.pm
new file mode 100644
index 0000000..01de012
--- /dev/null
+++ b/lib/Arctica/Browser/Overlay/Version.pm
@@ -0,0 +1,65 @@
+################################################################################
+# _____ _
+# |_ _| |_ ___
+# | | | ' \/ -_)
+# |_| |_||_\___|
+# _ _ ____ _ _
+# / \ _ __ ___| |_(_) ___ __ _ | _ \ _ __ ___ (_) ___ ___| |_
+# / _ \ | '__/ __| __| |/ __/ _` | | |_) | '__/ _ \| |/ _ \/ __| __|
+# / ___ \| | | (__| |_| | (_| (_| | | __/| | | (_) | | __/ (__| |_
+# /_/ \_\_| \___|\__|_|\___\__,_| |_| |_| \___// |\___|\___|\__|
+# |__/
+# The Arctica Modular Remote Computing Framework
+#
+################################################################################
+#
+# Copyright (C) 2015-2016 The Arctica Project
+# http://http://arctica-project.org/
+#
+# This code is dual licensed: strictly GPL-2 or AGPL-3+
+#
+# GPL-2
+# -----
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; version 2 of the License.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the
+# Free Software Foundation, Inc.,
+#
+# 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# AGPL-3+
+# -------
+# This programm is free software; you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# This programm is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program; if not, write to the
+# Free Software Foundation, Inc.,
+# 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# Copyright (C) 2015-2016 Guangzhou Nianguan Electronics Technology Co.Ltd.
+# <opensource@gznianguan.com>
+# Copyright (C) 2015-2016 Mike Gabriel <mike.gabriel@das-netzwerkteam.de>
+#
+################################################################################
+package Arctica::Browser::Overlay::Version;
+use strict;
+
+use vars qw[$VERSION];
+
+$VERSION = '0.0.0.1';
diff --git a/lib/Arctica/Browser/Overlay/WebView.pm b/lib/Arctica/Browser/Overlay/WebView.pm
new file mode 100644
index 0000000..54fe15c
--- /dev/null
+++ b/lib/Arctica/Browser/Overlay/WebView.pm
@@ -0,0 +1,184 @@
+################################################################################
+# _____ _
+# |_ _| |_ ___
+# | | | ' \/ -_)
+# |_| |_||_\___|
+# _ _ ____ _ _
+# / \ _ __ ___| |_(_) ___ __ _ | _ \ _ __ ___ (_) ___ ___| |_
+# / _ \ | '__/ __| __| |/ __/ _` | | |_) | '__/ _ \| |/ _ \/ __| __|
+# / ___ \| | | (__| |_| | (_| (_| | | __/| | | (_) | | __/ (__| |_
+# /_/ \_\_| \___|\__|_|\___\__,_| |_| |_| \___// |\___|\___|\__|
+# |__/
+# The Arctica Modular Remote Computing Framework
+#
+################################################################################
+#
+# Copyright (C) 2015-2016 The Arctica Project
+# http://http://arctica-project.org/
+#
+# This code is dual licensed: strictly GPL-2 or AGPL-3+
+#
+# GPL-2
+# -----
+# This program is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; version 2 of the License.
+#
+# This program is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with this program; if not, write to the
+# Free Software Foundation, Inc.,
+#
+# 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# AGPL-3+
+# -------
+# This programm is free software; you can redistribute it and/or modify
+# it under the terms of the GNU Affero General Public License as published by
+# the Free Software Foundation; either version 3 of the License, or
+# (at your option) any later version.
+#
+# This programm is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+# GNU Affero General Public License for more details.
+#
+# You should have received a copy of the GNU Affero General Public License
+# along with this program; if not, write to the
+# Free Software Foundation, Inc.,
+# 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA.
+#
+# Copyright (C) 2015-2016 Guangzhou Nianguan Electronics Technology Co.Ltd.
+# <opensource@gznianguan.com>
+# Copyright (C) 2015-2016 Mike Gabriel <mike.gabriel@das-netzwerkteam.de>
+#
+################################################################################
+package Arctica::Browser::Overlay::WebView;
+use strict;
+use Gtk3;
+use Glib 'TRUE', 'FALSE';
+use Gtk3::WebKit;
+use Data::Dumper;
+# Be very selective about what (if any) gets exported by default:
+our @EXPORT = qw();
+# And be mindful of what we let the caller request, too:
+our @EXPORT_OK = qw( );
+
+sub new {
+ my $class_name = $_[0];
+ my $related_toolbar = $_[1];
+
+ my $self = {
+ isArctica => 1,
+ aobject_name => "browser_webview",
+ };
+ bless($self, $class_name);
+
+ if ($related_toolbar) {
+ if ($related_toolbar->{'aobject_name'} eq "browser_toolbar") {
+ $self->{'toolbar'} = $related_toolbar;
+ $related_toolbar->{'webview'} = $self;
+ } else {
+ die("Thats not a toolbar you're trying to pass of as one, is it?");
+ }
+ } else {
+ $related_toolbar = FALSE;
+ }
+
+
+ $self->_gen_webview_main;
+
+ return $self;
+}
+
+
+sub return_webview {
+ my $self = $_[0];
+ if ($self->{'_gtk'}{'webview'}{'main_container'}) {
+ return $self->{'_gtk'}{'webview'}{'main_container'};
+ } else {
+ die("Can't return a webview that does not exist, can we?");
+ }
+}
+
+sub _gen_webview_main {
+ my $self = $_[0];
+
+ $self->{'_gtk'}{'webview'}{'main_container'} = Gtk3::Overlay->new();
+
+ $self->{'_gtk'}{'webview'}{'thewebview'} = Gtk3::WebKit::WebView->new();
+ $self->{'_gtk'}{'webview'}{'thewebview'}->load_uri("http://bing.com/");#
+ $self->{'_gtk'}{'webview'}{'scroller'} = Gtk3::ScrolledWindow->new();
+ $self->{'_gtk'}{'webview'}{'scroller'}->add($self->{'_gtk'}{'webview'}{'thewebview'});
+ $self->{'_gtk'}{'webview'}{'main_container'}->add($self->{'_gtk'}{'webview'}{'scroller'});
+
+ $self->{'_gtk'}{'webview'}{'bottom_overlay_text'} = Gtk3::Label->new();
+ $self->{'_gtk'}{'webview'}{'bottom_overlay_text'}->set_halign('start');
+ $self->{'_gtk'}{'webview'}{'bottom_overlay_text'}->set_valign('end');
+ $self->{'_gtk'}{'webview'}{'main_container'}->add_overlay($self->{'_gtk'}{'webview'}{'bottom_overlay_text'});
+
+
+ $self->{'_gtk'}{'webview'}{'thewebview'}->signal_connect( 'hovering-over-link' => sub {$self->_sigfunc_webview_hover_over_link($_[2]);}, undef );
+ $self->{'_gtk'}{'webview'}{'thewebview'}->signal_connect( 'notify::load-status' => sub {$self->_sigfunc_webview_notify_load_status;}, undef );
+ $self->{'_gtk'}{'webview'}{'thewebview'}->signal_connect( 'notify::progress' => sub {$self->_sigfunc_webview_notify_progress;}, undef );
+# $self->{'_gtk'}{'webview'}{'thewebview'}->signal_connect( 'notify::title' => sub {} , undef );
+
+}
+
+sub ext_sigfunc {
+ my $self = $_[0];
+ my $func = $_[1];
+ my $func_data = $_[2];
+# print "WEBVIEW SIGFUNC:\t$_[1]\n";
+# print Dumper($_[2]);
+ if ($func eq "reload") {
+ $self->{'_gtk'}{'webview'}{'thewebview'}->reload();
+ } elsif ($func eq "stop") {
+ $self->{'_gtk'}{'webview'}{'thewebview'}->stop_loading();
+ } elsif ($func eq "load_uri") {
+ $self->{'_gtk'}{'webview'}{'thewebview'}->load_uri($func_data);
+ } elsif ($func eq "history_back") {
+ $self->{'_gtk'}{'webview'}{'thewebview'}->go_back;
+ } elsif ($func eq "history_forward") {
+ $self->{'_gtk'}{'webview'}{'thewebview'}->go_forward;
+ }
+}
+
+sub _sigfunc_webview_notify_load_status {
+ my $self = $_[0];
+ my $status = $self->{'_gtk'}{'webview'}{'thewebview'}->get('load_status');
+ if ($status eq 'committed') {
+ my $uri = $self->{'_gtk'}{'webview'}{'thewebview'}->get_uri();
+# if ($uri) {print "URI:\t$uri\n";}
+ $self->{'toolbar'}->ext_sigfunc('load_committed',$uri)
+ } elsif ($status eq 'finished') {
+ my $uri = $self->{'_gtk'}{'webview'}{'thewebview'}->get_uri();
+ $self->{'toolbar'}->ext_sigfunc('load_finished',$uri)
+ } else {
+# print "WTF LS:\t$status\n";
+ }
+}
+
+sub _sigfunc_webview_notify_progress {
+ my $self = $_[0];
+ my $progress = $self->{'_gtk'}{'webview'}{'thewebview'}->get('progress');
+ if ($progress) {
+ $self->{'toolbar'}->ext_sigfunc('load_progress',sprintf("%.2f", $progress));
+ }
+}
+
+sub _sigfunc_webview_hover_over_link {
+ my $self = $_[0];
+ my $link = $_[1];
+ if ($link) {
+ $self->{'_gtk'}{'webview'}{'bottom_overlay_text'}->set_text($link);
+ } else {
+ $self->{'_gtk'}{'webview'}{'bottom_overlay_text'}->set_text('');
+ }
+}
+
+1;