summaryrefslogtreecommitdiffstats
path: root/chrome/browser
diff options
context:
space:
mode:
authoragl@chromium.org <agl@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-02-26 02:30:12 +0000
committeragl@chromium.org <agl@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98>2009-02-26 02:30:12 +0000
commitfceaeae013de84077051f04940a97193497793db (patch)
treebde79bf3ffe4f037d52c8c6391c29068f8eccb5f /chrome/browser
parent100897aabac0a58a473d8fb01cdf5d532ea6e4be (diff)
downloadchromium_src-fceaeae013de84077051f04940a97193497793db.zip
chromium_src-fceaeae013de84077051f04940a97193497793db.tar.gz
chromium_src-fceaeae013de84077051f04940a97193497793db.tar.bz2
Linux: add splash screen
In preparation for an internal launch, this adds a splash screen as the startup URL for Linux which has a few FAQs. git-svn-id: svn://svn.chromium.org/chrome/trunk/src@10442 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser')
-rw-r--r--chrome/browser/browser.cc3
-rw-r--r--chrome/browser/browser_about_handler.cc16
-rw-r--r--chrome/browser/browser_about_handler.h3
-rw-r--r--chrome/browser/browser_resources.grd1
-rw-r--r--chrome/browser/resources/linux-splash.html75
-rw-r--r--chrome/browser/tab_contents/tab_contents_factory.cc11
6 files changed, 106 insertions, 3 deletions
diff --git a/chrome/browser/browser.cc b/chrome/browser/browser.cc
index 5a88b68..311d500 100644
--- a/chrome/browser/browser.cc
+++ b/chrome/browser/browser.cc
@@ -2387,6 +2387,9 @@ void Browser::BuildPopupWindow(TabContents* source,
}
GURL Browser::GetHomePage() {
+#if defined(OS_LINUX)
+ return GURL("about:linux-splash");
+#endif
if (profile_->GetPrefs()->GetBoolean(prefs::kHomePageIsNewTabPage))
return NewTabUI::GetBaseURL();
GURL home_page = GURL(URLFixerUpper::FixupURL(
diff --git a/chrome/browser/browser_about_handler.cc b/chrome/browser/browser_about_handler.cc
index 511c4d1..7f25a60 100644
--- a/chrome/browser/browser_about_handler.cc
+++ b/chrome/browser/browser_about_handler.cc
@@ -61,6 +61,7 @@ static const char kStatsPath[] = "stats";
static const char kVersionPath[] = "version";
static const char kCreditsPath[] = "credits";
static const char kTermsPath[] = "terms";
+static const char kLinuxSplash[] = "linux-splash";
class AboutSource : public ChromeURLDataManager::DataSource {
public:
@@ -141,6 +142,12 @@ void AboutSource::StartDataRequest(const std::string& path_raw,
} else if (path == kTermsPath) {
response = BrowserAboutHandler::AboutTerms();
}
+#if defined(OS_LINUX)
+ else if (path == kLinuxSplash) {
+ response = BrowserAboutHandler::AboutLinuxSplash();
+ }
+#endif
+
FinishDataRequest(response, request_id);
}
@@ -304,6 +311,15 @@ std::string BrowserAboutHandler::AboutCredits() {
}
// static
+std::string BrowserAboutHandler::AboutLinuxSplash() {
+ static const std::string linux_splash_html =
+ ResourceBundle::GetSharedInstance().GetDataResource(
+ IDR_LINUX_SPLASH_HTML);
+
+ return linux_splash_html;
+}
+
+// static
std::string BrowserAboutHandler::AboutTerms() {
static const std::string terms_html =
ResourceBundle::GetSharedInstance().GetDataResource(
diff --git a/chrome/browser/browser_about_handler.h b/chrome/browser/browser_about_handler.h
index c90d42d..21ffb27 100644
--- a/chrome/browser/browser_about_handler.h
+++ b/chrome/browser/browser_about_handler.h
@@ -71,6 +71,9 @@ class BrowserAboutHandler : public WebContents {
// information about current state.
static void AboutMemory(AboutSource*, int request_id);
+ // This displays the Linux splash screen for development releases.
+ static std::string AboutLinuxSplash();
+
private:
ChromeURLDataManager::DataSource* about_source_;
DISALLOW_COPY_AND_ASSIGN(BrowserAboutHandler);
diff --git a/chrome/browser/browser_resources.grd b/chrome/browser/browser_resources.grd
index c97a02c..6ec01e6 100644
--- a/chrome/browser/browser_resources.grd
+++ b/chrome/browser/browser_resources.grd
@@ -23,6 +23,7 @@
<include name="IDR_CREDITS_HTML" file="resources\about_credits.html" flattenhtml="true" type="BINDATA" />
<include name="IDR_HISTORY_HTML" file="resources\history.html" flattenhtml="true" type="BINDATA" />
<include name="IDR_DOWNLOADS_HTML" file="resources\downloads.html" flattenhtml="true" type="BINDATA" />
+ <include name="IDR_LINUX_SPLASH_HTML" file="resources\linux-splash.html" flattenhtml="true" type="BINDATA" />
</includes>
</release>
</grit>
diff --git a/chrome/browser/resources/linux-splash.html b/chrome/browser/resources/linux-splash.html
new file mode 100644
index 0000000..e9adcf5
--- /dev/null
+++ b/chrome/browser/resources/linux-splash.html
@@ -0,0 +1,75 @@
+<!DOCTYPE html>
+<html lang="en-US">
+ <head>
+ <title>Chromium Alpha Warning</title>
+ <style>
+ div.heading {
+ width: 400px;
+ margin-left: auto;
+ margin-right: auto;
+ text-align: center;
+ font-size: 2em;
+ font-weight: bold;
+ }
+
+ h3 {
+ font-size: 1em;
+ margin-left: -1em;
+ color: black;
+ }
+
+ div.faq {
+ margin-left: 1em;
+ width: 60%;
+ color: #444;
+ }
+ </style>
+ </head>
+ <body>
+ <div class="heading">
+ <div>
+ <img src="">
+ </div>
+ This browser is not ready yet!
+ </div>
+
+ <p>This is a <i>pre-alpha</i> build of Chromium on Linux. It is woefully
+ incomplete.</p>
+
+ <div class="faq">
+
+ <h3>It's &lsquo;Chromium&rsquo;, not &lsquo;Google Chrome&rsquo;:</h3>
+
+ <p><a href="http://code.google.com/chromium/">Chromium</a> is an open
+ source browser project. <a href="http://www.google.com/chrome">Google
+ Chrome</a> is a browser from Google, based on the Chromium project. This
+ is a build of Chromium. No versions of Google Chrome for Linux will exist
+ until Google makes an official release.</p>
+
+ <h3>Please don't file bugs:</h3>
+
+ <p>At this point there are so many gaping holes that finding bugs is not
+ the problem and dealing with them is just a distraction.</p>
+
+ <h3>Blogging about it is not helpful:</h3>
+
+ <p>Chromium's problem is not a lack of media attention, but an excess of
+ it. Coverage encourages people to try it out in this incomplete state which
+ only creates negative first impressions. Also, dealing with
+ misunderstandings/questions etc only distracts the team from the job of
+ improving it.</p>
+
+ <p>Likewise, keep in mind that we won't see your comments if they're on a
+ random blog somewhere.</p>
+
+ <h3>How to help:</h3>
+
+ <p>Chromium is an open source project, you are welcome to help out. We have
+ <a href="http://dev.chromium.org/">documentation for developers</a> as well
+ as mailing lists and an IRC channel.</p>
+
+ </div>
+
+ <p></p>
+ </body>
+</html>
diff --git a/chrome/browser/tab_contents/tab_contents_factory.cc b/chrome/browser/tab_contents/tab_contents_factory.cc
index 045a01c..a65d9de 100644
--- a/chrome/browser/tab_contents/tab_contents_factory.cc
+++ b/chrome/browser/tab_contents/tab_contents_factory.cc
@@ -48,6 +48,9 @@ TabContents* TabContents::CreateWithType(TabContentsType type,
case TAB_CONTENTS_WEB:
contents = new WebContents(profile, instance, NULL, MSG_ROUTING_NONE, NULL);
break;
+ case TAB_CONTENTS_ABOUT_UI:
+ contents = new BrowserAboutHandler(profile, instance, NULL);
+ break;
// TODO(port): remove this platform define, either by porting the tab contents
// types or removing them completely.
#if defined(OS_WIN)
@@ -57,9 +60,6 @@ TabContents* TabContents::CreateWithType(TabContentsType type,
case TAB_CONTENTS_NATIVE_UI:
contents = new NativeUIContents(profile);
break;
- case TAB_CONTENTS_ABOUT_UI:
- contents = new BrowserAboutHandler(profile, instance, NULL);
- break;
case TAB_CONTENTS_DEBUGGER:
case TAB_CONTENTS_NEW_TAB_UI:
case TAB_CONTENTS_DOM_UI:
@@ -116,6 +116,11 @@ TabContentsType TabContents::TypeForURL(GURL* url) {
return TAB_CONTENTS_DOM_UI;
#elif defined(OS_POSIX)
+ TabContentsType type(TAB_CONTENTS_UNKNOWN_TYPE);
+ if (BrowserURLHandler::HandleBrowserURL(url, &type) &&
+ type == TAB_CONTENTS_ABOUT_UI) {
+ return type;
+ }
NOTIMPLEMENTED();
#endif