[Sugar-devel] [PATCH Browse] Error page SL #3500

Manuel Kaufmann humitos at gmail.com
Wed Sep 19 07:38:54 EDT 2012


Added an "Error page" with Sugar style that informs the users about
the the page could not be loaded for any reason.

This patch contains a HTML template (error_page.tmpl) that is used to
generate the error page with the correct language.

Signed-off-by: Manuel Kaufmann <humitos at gmail.com>
---
 browser.py           | 22 +++++++++++++++++++++
 data/error_page.tmpl | 54 ++++++++++++++++++++++++++++++++++++++++++++++++++++
 2 files changed, 76 insertions(+)
 create mode 100644 data/error_page.tmpl

diff --git a/browser.py b/browser.py
index de546f2..52e05bd 100644
--- a/browser.py
+++ b/browser.py
@@ -58,6 +58,9 @@ _NON_SEARCH_REGEX = re.compile('''
     ^file:.*$)
     ''', re.VERBOSE)
 
+DEFAULT_ERROR_PAGE = os.path.join(activity.get_bundle_path(),
+                                  'data/error_page.tmpl')
+
 
 class CommandListener(object):
     def __init__(self, window):
@@ -462,6 +465,7 @@ class Browser(WebKit.WebView):
                      self.__mime_type_policy_cb)
         self.connect('new-window-policy-decision-requested',
                      self.__new_window_policy_cb)
+        self.connect('load-error', self.__load_error_cb)
 
         try:
             self.connect('run-file-chooser', self.__run_file_chooser)
@@ -603,6 +607,24 @@ class Browser(WebKit.WebView):
         downloadmanager.add_download(download, browser)
         return True
 
+    def __load_error_cb(self, web_view, web_frame, uri, web_error):
+        """Show Sugar's error page"""
+
+        data = {
+            'page_title': _('This web page could not be loaded'),
+            'title': _('This web page could not be loaded'),
+            'message': _('"%s" could not be loaded. Please check for<br/>'
+                         'typing errors, and make sure you are connected '
+                         'to the internet.') % uri,
+            'btn_value': _('Try again'),
+            'url': uri,
+            }
+
+        html = open(DEFAULT_ERROR_PAGE, 'r').read() % data
+        web_frame.load_alternate_string(html, '', uri)
+
+        return True
+
 
 class PopupDialog(Gtk.Window):
     def __init__(self):
diff --git a/data/error_page.tmpl b/data/error_page.tmpl
new file mode 100644
index 0000000..68c76f2
--- /dev/null
+++ b/data/error_page.tmpl
@@ -0,0 +1,54 @@
+<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
+<html xmlns="http://www.w3.org/1999/xhtml">
+  <head>
+    <title>%(page_title)s</title>
+    <style type="text/css">
+      body {
+	  font-family: sans-serif;
+	  text-align:center;
+	  color: #a1a1a1;
+      }
+
+      #browse-logo {
+	  align: center;
+	  width: 130px;
+      }
+
+      p {
+	  font-size: 1em;
+      }
+
+      #button {
+	  color: white;
+	  min-width: 150px;
+	  height: 35px;
+	  background-color: #a3a1a3;
+	  border: 0;
+	  font-size: 12pt;
+	  font-weight: bold;
+	  -webkit-border-radius: 20px;
+	  background-image: url("");
+	  background-position: 16px;
+	  background-repeat: no-repeat;
+	  text-align: center;
+	  padding-left: 40px;
+	  padding-right: 15px;
+      }
+
+      #container {
+          /* we need double percent sign here because
+             of Python sustitution */
+	  margin: 15%%;
+      }
+    </style>
+  </head>
+
+  <body>
+    <div id="container">
+      <img id="browse-logo" src=""></img>
+      <h3>%(title)s</h3>
+      <p>%(message)s</p>
+      <input id="button" type="button" value="%(btn_value)s" onclick="location.href='%(url)s';" />
+    </div>
+  </body>
+</html>
-- 
1.7.11.4



More information about the Sugar-devel mailing list