summaryrefslogtreecommitdiffstats
path: root/chrome
diff options
context:
space:
mode:
authorcpu@google.com <cpu@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-12-08 20:30:53 +0000
committercpu@google.com <cpu@google.com@0039d316-1c4b-4281-b951-d872f2087c98>2008-12-08 20:30:53 +0000
commitb3d565264e6073bd00e4dfd81c8f887ea01fb58c (patch)
treeb37f2589de3352d27f2bbcca2a579780f8c0b168 /chrome
parente292fca9e47cba237bb5b2d885f900eddecd70c5 (diff)
downloadchromium_src-b3d565264e6073bd00e4dfd81c8f887ea01fb58c.zip
chromium_src-b3d565264e6073bd00e4dfd81c8f887ea01fb58c.tar.gz
chromium_src-b3d565264e6073bd00e4dfd81c8f887ea01fb58c.tar.bz2
More addions to the installer html dialog class
- EulaDialog subclass - Wired the output parameter BUG=1468838 Review URL: http://codereview.chromium.org/13601 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@6533 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome')
-rwxr-xr-xchrome/installer/setup/main.cc17
-rw-r--r--chrome/installer/util/html_dialog.h24
-rw-r--r--chrome/installer/util/html_dialog_impl.cc76
3 files changed, 106 insertions, 11 deletions
diff --git a/chrome/installer/setup/main.cc b/chrome/installer/setup/main.cc
index 4aa4f37..5307c1c 100755
--- a/chrome/installer/setup/main.cc
+++ b/chrome/installer/setup/main.cc
@@ -21,6 +21,7 @@
#include "chrome/installer/util/browser_distribution.h"
#include "chrome/installer/util/delete_tree_work_item.h"
#include "chrome/installer/util/helper.h"
+#include "chrome/installer/util/html_dialog.h"
#include "chrome/installer/util/install_util.h"
#include "chrome/installer/util/logging_installer.h"
#include "chrome/installer/util/lzma_util.h"
@@ -430,8 +431,19 @@ installer_util::InstallStatus UninstallChrome(const CommandLine& cmd_line,
*version, remove_all, force);
}
-} // namespace
+// This function is temporary and meant to live while we get our eula dialogs
+// looking sharp. If the cmd line has --eula-test=path then the eula dialog
+// will be shown and no matter what the selection is the installer will exit.
+bool HandleEULADialog(const CommandLine& cmdline) {
+ std:: wstring eula_path(cmdline.GetSwitchValue(L"eula-test"));
+ if (eula_path.empty())
+ return true;
+ installer::EulaHTMLDialog dlg(eula_path);
+ dlg.ShowModal();
+ return false;
+}
+} // namespace
int WINAPI wWinMain(HINSTANCE instance, HINSTANCE prev_instance,
wchar_t* command_line, int show_command) {
@@ -446,6 +458,9 @@ int WINAPI wWinMain(HINSTANCE instance, HINSTANCE prev_instance,
bool system_install = (options & installer_util::SYSTEM_LEVEL) != 0;
LOG(INFO) << "system install is " << system_install;
+ if (!HandleEULADialog(parsed_command_line))
+ return 0;
+
// Check to make sure current system is WinXP or later. If not, log
// error message and get out.
if (!InstallUtil::IsOSSupported()) {
diff --git a/chrome/installer/util/html_dialog.h b/chrome/installer/util/html_dialog.h
index 3455d73..91ace2d 100644
--- a/chrome/installer/util/html_dialog.h
+++ b/chrome/installer/util/html_dialog.h
@@ -7,6 +7,8 @@
#include <string>
+#include "base/basictypes.h"
+
// This is the interface for creating HTML-based Dialogs *before* Chrome has
// been installed or when there is a suspicion chrome is not working. In
// other words, the dialogs use another native html rendering engine. In the
@@ -56,6 +58,28 @@ class HTMLDialog {
// different underlying implementation according to the url protocol.
HTMLDialog* CreateNativeHTMLDialog(const std::wstring& url);
+// This class leverages HTMLDialog to create a dialog that is suitable
+// for a end-user-agreement modal dialog.
+class EulaHTMLDialog {
+ public:
+ // |file| points to an html file on disk.
+ explicit EulaHTMLDialog(const std::wstring& file);
+ ~EulaHTMLDialog();
+
+ // Shows the dialog and blocks for user input. The return value is true if
+ // the user accepted and false otherwise.
+ bool ShowModal();
+
+ private:
+ class Customizer : public HTMLDialog::CustomizationCallback {
+ public:
+ virtual void OnBeforeCreation(void** extra);
+ virtual void OnBeforeDisplay(void* window);
+ };
+
+ HTMLDialog* dialog_;
+ DISALLOW_COPY_AND_ASSIGN(EulaHTMLDialog);
+};
} // namespace installer
diff --git a/chrome/installer/util/html_dialog_impl.cc b/chrome/installer/util/html_dialog_impl.cc
index 2ba8974..197cebb 100644
--- a/chrome/installer/util/html_dialog_impl.cc
+++ b/chrome/installer/util/html_dialog_impl.cc
@@ -18,16 +18,33 @@ typedef HRESULT (CALLBACK *ShowHTMLDlg)(HWND parent_hwnd,
VARIANT *out_args);
} // namespace.
-
namespace installer {
// Windows implementation of the HTML dialog class. The main danger with
// using the IE embedded control as a child window of a custom window is that
// it still contains too much browser functionality, allowing the user to do
-// things that are not expected of a plain dialog. ShowHTMLDialog api solves
+// things that are not expected of a plain dialog. ShowHTMLDialog API solves
// that problem but gives us a not very customizable frame. We solve that
// using hooks to end up with a robust dialog at the expense of having to do
-// the buttons in html itself.
+// the buttons in html itself, like so:
+//
+// <form onsubmit="submit_it(this); return false;">
+// <input name="accept" type="checkbox" /> My cool option
+// <input name="submit" type="submit" value="[accept]" />
+// </form>
+//
+// function submit_it(f) {
+// if (f.accept.checked) {
+// window.returnValue = 1; <-- this matches HTML_DLG_ACCEPT
+// } else {
+// window.returnValue = 2; <-- this matches HTML_DLG_DECLINE
+// }
+// window.close();
+// }
+//
+// Note that on the submit handler you need to set window.returnValue to one of
+// the values of DialogResult and call window.close().
+
class HTMLDialogWin : public HTMLDialog {
public:
HTMLDialogWin(const std::wstring& url) : url_(url) {
@@ -37,11 +54,10 @@ class HTMLDialogWin : public HTMLDialog {
virtual DialogResult ShowModal(void* parent_window,
CustomizationCallback* callback) {
- if (!InternalDoDialog(callback))
+ int result = HTML_DLG_DECLINE;
+ if (!InternalDoDialog(callback, &result))
return HTML_DLG_ERROR;
- // TODO(cpu): Remove the HTML_DLG_ACCEPT and read the real return
- // value from the ShowHTMLDialog call.
- return HTML_DLG_ACCEPT;
+ return static_cast<DialogResult>(result);
}
// TODO(cpu): Not yet implemented.
@@ -50,7 +66,7 @@ class HTMLDialogWin : public HTMLDialog {
}
private:
- bool InternalDoDialog(CustomizationCallback* callback);
+ bool InternalDoDialog(CustomizationCallback* callback, int* result);
static LRESULT CALLBACK MsgFilter(int code, WPARAM wParam, LPARAM lParam);
std::wstring url_;
@@ -86,7 +102,8 @@ LRESULT HTMLDialogWin::MsgFilter(int code, WPARAM wParam, LPARAM lParam) {
return ::CallNextHookEx(hook_, code, wParam, lParam);
}
-bool HTMLDialogWin::InternalDoDialog(CustomizationCallback* callback) {
+bool HTMLDialogWin::InternalDoDialog(CustomizationCallback* callback,
+ int* result) {
if (!mshtml_)
return false;
ShowHTMLDlg show_html_dialog =
@@ -109,10 +126,17 @@ bool HTMLDialogWin::InternalDoDialog(CustomizationCallback* callback) {
callback_ = callback;
}
+ VARIANT v_result;
+ ::VariantInit(&v_result);
+
// Creates the window with the embedded IE control in a modal loop.
- HRESULT hr = show_html_dialog(NULL, url_moniker, NULL, extra_args, NULL);
+ HRESULT hr = show_html_dialog(NULL, url_moniker, NULL, extra_args, &v_result);
url_moniker->Release();
+ if (v_result.vt == VT_I4)
+ *result = v_result.intVal;
+ ::VariantClear(&v_result);
+
if (hook_) {
::UnhookWindowsHookEx(hook_);
callback_ = NULL;
@@ -121,5 +145,37 @@ bool HTMLDialogWin::InternalDoDialog(CustomizationCallback* callback) {
return SUCCEEDED(hr);
}
+// EulaHTMLDialog implementation ---------------------------------------------
+
+void EulaHTMLDialog::Customizer::OnBeforeCreation(void** extra) {
+}
+
+// The customization of the window consists in removing the close button and
+// replacing the existing 'e' icon with the standard informational icon.
+void EulaHTMLDialog::Customizer::OnBeforeDisplay(void* window) {
+ if (!window)
+ return;
+ HWND top_window = static_cast<HWND>(window);
+ LONG_PTR style = ::GetWindowLongPtrW(top_window, GWL_STYLE);
+ ::SetWindowLongPtrW(top_window, GWL_STYLE, style & ~WS_SYSMENU);
+ HICON ico = ::LoadIcon(NULL, IDI_INFORMATION);
+ ::SendMessageW(top_window, WM_SETICON, ICON_SMALL,
+ reinterpret_cast<LPARAM>(ico));
+}
+
+EulaHTMLDialog::EulaHTMLDialog(const std::wstring& file) {
+ dialog_ = CreateNativeHTMLDialog(file);
+}
+
+EulaHTMLDialog::~EulaHTMLDialog() {
+ delete dialog_;
+}
+
+bool EulaHTMLDialog::ShowModal() {
+ Customizer customizer;
+ dialog_->ShowModal(NULL, &customizer);
+ return false;
+}
+
} // namespace installer