Permalink
Browse files

GUI: Add Error page to SC_WebPage, Add Error.html

  • Loading branch information...
1 parent 46543c9 commit e3d909ba2317e4904c87bf2cedce69d7d1eb0818 @ripply ripply committed Jan 22, 2014
Showing with 167 additions and 0 deletions.
  1. +112 −0 Error.html
  2. +55 −0 qt/simulationcraftqt.hpp
View
@@ -0,0 +1,112 @@
+<html>
+
+ <head>
+
+ <title>Could not process that request! Oops</title>
+
+ <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
+
+ <style type="text/css">
+ body { padding: 5px 25px 25px 25px; font-family: "Lucida Grande", Arial, sans-serif; font-size: 14px; background-color: #f9f9f9; color: #333; text-align: center; }
+ p { margin-top: 1em; }
+ h1, h2, h3, h4, h5, h6 { color: #777; margin-top: 1em; margin-bottom: 0.5em; }
+ h1, h2 { margin: 0; padding: 2px 2px 0 2px; }
+ h1 { font-size: 24px; }
+ h2 { font-size: 18px; }
+ h3 { margin: 0 0 4px 0; font-size: 16px; }
+ a { color: #666688; text-decoration: none; }
+ a:hover, a:active { color: #333; }
+ ul, ol { padding-left: 20px; }
+ ul.float, ol.float { padding: 0; }
+ ul.float li, ol.float li { display: inline; float: left; padding-right: 6px; margin-right: 6px; list-style-type: none; border-right: 2px solid #eee; }
+ .spaced li { margin-top: 1em;}
+ .clear { clear: both; }
+ .hide, .charts span { display: none; }
+ .center { text-align: center; }
+ .float { float: left; }
+ .mt { margin-top: 20px; }
+ .mb { margin-bottom: 20px; }
+ .toggle { cursor: pointer; }
+ h2.toggle { padding-left: 16px; background: url() 0 -10px no-repeat; }
+ h2.open { margin-bottom: 10px; background-position: 0 9px; }
+ h3.toggle { padding-left: 16px; background: url() 0 -11px no-repeat; }
+ h3.open { background-position: 0 7px; }
+ h4.toggle { margin: 0 0 8px 0; padding-left: 12px; background: url() 0 -8px no-repeat; }
+ h4.open { background-position: 0 6px; }
+ a.toggle-details { margin: 0 0 8px 0; padding-left: 12px; background: url() 0 4px no-repeat; }
+ a.open { background-position: 0 -11px; }
+ td.small a.toggle-details { background-position: 0 2px; }
+ td.small a.open { background-position: 0 -13px; }
+ .toggle-content { display: none; }
+ #active-help, .help-box { display: none; }
+ #active-help { position: absolute; width: auto; padding: 3px; background: #fff; z-index: 10; }
+ #active-help-dynamic { padding: 6px 6px 18px 6px; background: #eeeef5; outline: 1px solid #ddd; font-size: 13px; text-align: left; }
+ #active-help .close { position: absolute; right: 10px; bottom: 4px; }
+ .help-box h3 { margin: 0; font-size: 12px; }
+ .help-box p { margin: 0 0 10px 0; }
+ .help-box { border: 1px solid #ccc; background-color: #fff; padding: 10px; }
+ a.help { cursor: help; }
+ .section { position: relative; max-width: 1260px; padding: 8px; margin-left: auto; margin-right: auto; margin-bottom: -1px; border: 1px solid #ccc; background-color: #fff; -moz-box-shadow: 4px 4px 4px #bbb; -webkit-box-shadow: 4px 4px 4px #bbb; box-shadow: 4px 4px 4px #bbb; text-align: left; }
+ .section-open { margin-top: 25px; margin-bottom: 25px; -moz-border-radius: 10px; -khtml-border-radius: 10px; -webkit-border-radius: 10px; border-radius: 10px; }
+ .grouped-first { -moz-border-radius-topright: 10px; -moz-border-radius-topleft: 10px; -khtml-border-top-right-radius: 10px; -khtml-border-top-left-radius: 10px; -webkit-border-top-right-radius: 10px; -webkit-border-top-left-radius: 10px; border-top-right-radius: 10px; border-top-left-radius: 10px; }
+ .grouped-last { -moz-border-radius-bottomright: 10px; -moz-border-radius-bottomleft: 10px; -khtml-border-bottom-right-radius: 10px; -khtml-border-bottom-left-radius: 10px; -webkit-border-bottom-right-radius: 10px; -webkit-border-bottom-left-radius: 10px; border-bottom-right-radius: 10px; border-bottom-left-radius: 10px; }
+ .section .toggle-content { padding: 0 0 20px 14px; }
+ #raid-summary .toggle-content { padding-bottom: 0px; }
+ ul.params { padding: 0; }
+ ul.params li { float: left; padding: 2px 10px 2px 10px; margin-right: 10px; list-style-type: none; background: #eeeef5; font-family: "Lucida Grande", Arial, sans-serif; font-size: 12px; }
+ .player h2 { margin: 0; }
+ .player ul.params { position: relative; top: 2px; }
+ #masthead img { display: block; margin-left: auto; margin-right: auto; }
+ #masthead h2 { margin: 10px 0 5px 0; }
+ #notice { border: 1px solid #ddbbbb; background: #ffdddd; font-size: 12px; }
+ #notice h2 { margin-bottom: 10px; }
+ #masthead ul.toc { padding: 0; }
+ #masthead ul.toc li { list-style-type: none; }
+ #masthead ul.toc li ul { padding-left: 18px; }
+ #masthead ul.toc li ul li { list-style-type: circle; font-size: 13px; }
+ .charts { margin: 10px 60px 0 4px; float: left; width: 550px; text-align: center; }
+ .charts img { padding: 8px; margin: 0 auto; margin-bottom: 20px; border: 1px solid #ccc; -moz-border-radius: 6px; -khtml-border-radius: 6px; -webkit-border-radius: 6px; border-radius: 6px; -moz-box-shadow: inset 1px 1px 4px #ccc; -webkit-box-shadow: inset 1px 1px 4px #ccc; box-shadow: inset 1px 1px 4px #ccc; }
+ .talents div.float { width: auto; margin-right: 50px; }
+ table.sc { border: 0; background-color: #eee; }
+ table.sc tr { background-color: #fff; }
+ table.sc tr.head { background-color: #aaa; color: #fff; }
+ table.sc tr.odd { background-color: #f3f3f3; }
+ table.sc th { padding: 2px 4px; text-align: center; background-color: #aaa; color: #fcfcfc; }
+ table.sc th.small { padding: 2px 2px; font-size: 12px; }
+ table.sc th a { color: #fff; text-decoration: underline; }
+ table.sc th a:hover, table.sc th a:active { color: #f1f1ff; }
+ table.sc td { padding: 2px 4px; text-align: center; font-size: 13px; }
+ table.sc td.small { padding: 2px 2px; font-size: 11px; }
+ table.sc th.left, table.sc td.left, table.sc tr.left th, table.sc tr.left td { text-align: left; padding-right: 6px; }
+ table.sc th.right, table.sc td.right, table.sc tr.right th, table.sc tr.right td { text-align: right; padding-right: 6px; }
+ table.sc tr.details td { padding: 0 0 15px 15px; text-align: left; background-color: #fff; }
+ table.sc tr.details td ul { padding: 0; margin: 4px 0 8px 0; }
+ table.sc tr.details td ul li { clear: both; padding: 2px; list-style-type: none; }
+ table.sc tr.details td ul li span.label { display: block; float: left; width: 150px; margin-right: 4px; background: #f3f3f3; }
+ table.sc tr.details td ul li span.tooltip { display: block; float: left; width: 190px; }
+ table.sc tr.details td ul li span.tooltip-wider { display: block; float: left; width: 350px; }
+ table.sc tr.details td div.float { width: 350px; }
+ table.sc tr.details td div.float h5 { margin-top: 4px; }
+ table.sc tr.details td div.float ul { margin: 0 0 12px 0; }
+ table.sc td.filler { background-color: #ccc; }
+ table.sc .dynamic-buffs tr.details td ul li span.label { width: 120px; }
+ .sample-sequence { width: 500px; word-wrap: break-word; outline: 1px solid #ddd; background: #fcfcfc; padding: 6px; font-family: "Lucida Console", Monaco, monospace; font-size: 12px; }
+ </style>
+ <script>
+ function reloadPage()
+ {
+ location.reload();
+ }
+ </script>
+
+ </head>
+
+ <body>
+ <div id="masthead" class="section section-open">
+ <p style="text-align: center">Oops! An error occured loading <code><a href="SITE_URL">SITE_URL</a></code>
+ <p style="text-align: center"><b>ERROR_DOMAIN ERROR_NUMBER: ERROR_STRING</b></p>
+ <p style="text-align: right; margin-right: 20px"><input type="button" value="Reload page" onclick="reloadPage()"></p>
+ </p>
+ </div>
+ </body>
+</html>
@@ -3482,6 +3482,61 @@ class SC_WebPage : public QWebPage
QString userAgentForUrl( const QUrl& /* url */ ) const
{ return QString( "simulationcraft_gui" ); }
+protected:
+ virtual bool supportsExtension( Extension extension ) const
+ {
+ return extension == QWebPage::ErrorPageExtension;
+ }
+ virtual bool extension( Extension extension, const ExtensionOption* option = nullptr, ExtensionReturn* output = nullptr )
+ {
+ if ( extension != QWebPage::ErrorPageExtension )
+ {
+ return false;
+ }
+
+ const ErrorPageExtensionOption* errorOption = static_cast< const ErrorPageExtensionOption* >( option );
+
+ QString domain;
+ switch( errorOption -> domain )
+ {
+ case QWebPage::QtNetwork:
+ domain = tr( "Network Error" );
+ break;
+ case QWebPage::WebKit:
+ domain = tr( "WebKit Error" );
+ break;
+ case QWebPage::Http:
+ domain = tr( "HTTP Error" );
+ break;
+ default:
+ domain = tr( "Unknown Error" );
+ break;
+ }
+
+ QString html;
+ QFile errorHtml("Error.html");
+ if ( errorHtml.open( QIODevice::ReadOnly | QIODevice::Text ) )
+ {
+ html = QString::fromUtf8( errorHtml.readAll() );
+ errorHtml.close();
+ }
+ else
+ {
+ // VERY simple error page if we fail to load detailed error page
+ html = "<html><head><title>Error</title></head><body><p>Failed to load <a href=\"SITE_URL\">SITE_URL</a></p><p>ERROR_DOMAIN ERROR_NUMBER: ERROR_STRING</p></body></html>";
+ }
+
+ html = html.replace( "ERROR_NUMBER", QString::number( errorOption -> error ) );
+ html = html.replace( "ERROR_DOMAIN", domain );
+ html = html.replace( "ERROR_STRING", errorOption -> errorString );
+ html = html.replace( "SITE_URL", errorOption -> url.toString() );
+
+ ErrorPageExtensionReturn* errorReturn = static_cast< ErrorPageExtensionReturn* >( output );
+ errorReturn -> content = html.toUtf8();
+ errorReturn -> contentType = "text/html";
+ errorReturn -> baseUrl = errorOption -> url;
+ return true;
+ }
};
// ============================================================================

0 comments on commit e3d909b

Please sign in to comment.