Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(634)

Unified Diff: chrome_frame/turndown_prompt/turndown_prompt_window.cc

Issue 17153006: Chrome Frame turndown prompt. (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Created 7 years, 6 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: chrome_frame/turndown_prompt/turndown_prompt_window.cc
diff --git a/chrome_frame/turndown_prompt/turndown_prompt_window.cc b/chrome_frame/turndown_prompt/turndown_prompt_window.cc
new file mode 100644
index 0000000000000000000000000000000000000000..d2120c409edb735132c5a51f7ad123c600a9ad8f
--- /dev/null
+++ b/chrome_frame/turndown_prompt/turndown_prompt_window.cc
@@ -0,0 +1,116 @@
+// Copyright 2013 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#include "chrome_frame/turndown_prompt/turndown_prompt_window.h"
+
+#include <atlctrls.h>
+#include <commctrl.h>
+#include <shellapi.h>
+
+#include "base/compiler_specific.h"
+#include "chrome_frame/ready_mode/internal/url_launcher.h"
+#include "chrome_frame/simple_resource_loader.h"
+#include "grit/chrome_frame_dialogs.h"
+#include "grit/chromium_strings.h"
+
+// atlctrlx.h requires 'min' and 'max' macros, the definition of which conflicts
+// with STL headers. Hence we include them out of the order defined by style
+// guidelines. As a result you may not refer to std::min or std::max in this
+// file.
+#include <minmax.h> // NOLINT
+#include <atlctrlx.h> // NOLINT
+
+base::WeakPtr<TurndownPromptWindow> TurndownPromptWindow::CreateInstance(
+ InfobarContent::Frame* frame,
+ UrlLauncher* url_launcher,
+ const base::Closure& uninstall_callback) {
+ DCHECK(frame != NULL);
+ DCHECK(url_launcher != NULL);
+
+ base::WeakPtr<TurndownPromptWindow> instance(
+ (new TurndownPromptWindow(frame, url_launcher, uninstall_callback))
+ ->weak_ptr_factory_.GetWeakPtr());
+
+ DCHECK(!instance->IsWindow());
+
+ if (instance->Create(frame->GetFrameWindow()) == NULL) {
+ DPLOG(ERROR) << "Failed to create HWND for TurndownPromptWindow.";
+ return base::WeakPtr<TurndownPromptWindow>();
+ }
+
+ // Subclass the "Learn more." text to make it behave like a link. Clicks are
+ // routed to OnLearnMore().
+ CWindow rte = instance->GetDlgItem(IDC_TD_PROMPT_LINK);
+ instance->link_.reset(new CHyperLink());
+ instance->link_->SubclassWindow(rte);
+ instance->link_->SetHyperLinkExtendedStyle(HLINK_NOTIFYBUTTON,
+ HLINK_NOTIFYBUTTON);
+
+ return instance;
+}
+
+TurndownPromptWindow::TurndownPromptWindow(
+ InfobarContent::Frame* frame,
+ UrlLauncher* url_launcher,
+ const base::Closure& uninstall_closure)
+ : frame_(frame),
+ url_launcher_(url_launcher),
+ uninstall_closure_(uninstall_closure),
+ weak_ptr_factory_(this) {
+ // Use the theme of a tooltip to make the infobar pop.
+ CThemeImpl::SetThemeClassList(L"Tooltip");
+}
+
+TurndownPromptWindow::~TurndownPromptWindow() {}
+
+void TurndownPromptWindow::OnFinalMessage(HWND) {
+ delete this;
+}
+
+HBRUSH TurndownPromptWindow::OnCtlColorDlg(HDC device_context, HWND window) {
+ return brush_;
+}
+
+void TurndownPromptWindow::OnDestroy() {
+ frame_ = NULL;
+ brush_.Close();
+}
+
+BOOL TurndownPromptWindow::OnInitDialog(CWindow wndFocus, LPARAM lInitParam) {
+ // Ordinarily this would happen in OnCreate, but that isn't sent for a dialog.
+ if (!OpenThemeData())
+ DLOG(INFO) << "No theme data for class " << m_lpstrThemeClassList;
+ DlgResize_Init(false); // false => 'no gripper'
+ return TRUE;
+}
+
+void TurndownPromptWindow::OnThemeChanged() {
+ brush_.Close();
+}
+
+LRESULT TurndownPromptWindow::OnLearnMore(WORD /*wParam*/,
+ LPNMHDR /*lParam*/,
+ BOOL& /*bHandled*/) {
+ url_launcher_->LaunchUrl(SimpleResourceLoader::Get(
+ IDS_CHROME_FRAME_TURNDOWN_LEARN_MORE_URL));
+ return 0;
+}
+
+LRESULT TurndownPromptWindow::OnDismiss(WORD /*wNotifyCode*/,
+ WORD /*wID*/,
+ HWND /*hWndCtl*/,
+ BOOL& /*bHandled*/) {
+ frame_->CloseInfobar();
+ return 0;
+}
+
+LRESULT TurndownPromptWindow::OnUninstall(WORD /*wNotifyCode*/,
+ WORD /*wID*/,
+ HWND /*hWndCtl*/,
+ BOOL& /*bHandled*/) {
+ frame_->CloseInfobar();
+ if (!uninstall_closure_.is_null())
+ uninstall_closure_.Run();
+ return 0;
+}

Powered by Google App Engine
This is Rietveld 408576698