1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. 2 // Use of this source code is governed by a BSD-style license that can be 3 // found in the LICENSE file. 4 5 #ifndef CHROME_INSTALLER_UTIL_HTML_DIALOG_H_ 6 #define CHROME_INSTALLER_UTIL_HTML_DIALOG_H_ 7 8 #include <string> 9 10 #include "base/basictypes.h" 11 12 // This is the interface for creating HTML-based Dialogs *before* Chrome has 13 // been installed or when there is a suspicion chrome is not working. In 14 // other words, the dialogs use another native html rendering engine. In the 15 // case of Windows it is the the Internet Explorer control. 16 17 namespace installer { 18 19 // Interface for implementing a native HTML dialog. 20 class HTMLDialog { 21 public: 22 enum DialogResult { 23 HTML_DLG_ERROR = 0, // Dialog could not be shown. 24 HTML_DLG_ACCEPT = 1, // The user accepted (accept, ok, yes buttons). 25 HTML_DLG_DECLINE = 2, // The user declined (cancel, no, abort buttons). 26 HTML_DLG_RETRY = 3, // The user wants to retry the action. 27 HTML_DLG_IGNORE = 4, // The user wants to ignore the error and continue. 28 HTML_DLG_TIMEOUT = 5, // The dialog has timed out and defaults apply. 29 HTML_DLG_EXTRA = 6 // There is extra data as a string. See below. 30 }; 31 32 // Callbacks that allow to tweak the appearance of the dialog. 33 class CustomizationCallback { 34 public: 35 // Called before the native window is created. Use it to pass arbitrary 36 // parameters in |extra| to the rendering engine. 37 virtual void OnBeforeCreation(wchar_t** extra) = 0; 38 // The native window has been created and is about to be visible. Use it 39 // to customize the native |window| appearance. 40 virtual void OnBeforeDisplay(void* window) = 0; 41 42 protected: ~CustomizationCallback()43 virtual ~CustomizationCallback() {} 44 }; 45 ~HTMLDialog()46 virtual ~HTMLDialog() {} 47 48 // Shows the HTML in a modal dialog. The buttons and other UI are also done 49 // in HTML so each native implementation needs to map the user action into 50 // one of the 6 possible results of DialogResult. Important, call this 51 // method only from the main (or UI) thread. 52 virtual DialogResult ShowModal(void* parent_window, 53 CustomizationCallback* callback) = 0; 54 55 // If the result of ShowModal() was EXTRA, the information is available 56 // as a string using this method. 57 virtual std::wstring GetExtraResult() = 0; 58 }; 59 60 // Factory method for the native HTML Dialog. When done with the object use 61 // regular 'delete' operator to destroy the object. It might choose a 62 // different underlying implementation according to the url protocol. 63 HTMLDialog* CreateNativeHTMLDialog(const std::wstring& url, 64 const std::wstring& param); 65 66 // This class leverages HTMLDialog to create a dialog that is suitable 67 // for a end-user-agreement modal dialog. The html shows a fairly standard 68 // EULA form with the accept and cancel buttons and an optional check box 69 // to opt-in for sending usage stats and crash reports. 70 class EulaHTMLDialog { 71 public: 72 // |file| points to an html file on disk or to a resource via res:// spec. 73 // |param| is a string that will be passed to the dialog as a parameter via 74 // the window.dialogArguments property. 75 EulaHTMLDialog(const std::wstring& file, const std::wstring& param); 76 ~EulaHTMLDialog(); 77 78 enum Outcome { 79 REJECTED, // Declined EULA, mapped from HTML_DLG_ACCEPT (1). 80 ACCEPTED, // Accepted EULA no opt-in, from HTML_DLG_DECLINE (2). 81 ACCEPTED_OPT_IN, // Accepted EULA and opt-in, from HTML_DLG_EXTRA (6). 82 }; 83 84 // Shows the dialog and blocks for user input. The return value is one of 85 // the |Outcome| values and any form of failure maps to REJECTED. 86 Outcome ShowModal(); 87 88 private: 89 class Customizer : public HTMLDialog::CustomizationCallback { 90 public: 91 virtual void OnBeforeCreation(wchar_t** extra); 92 virtual void OnBeforeDisplay(void* window); 93 }; 94 95 HTMLDialog* dialog_; 96 DISALLOW_COPY_AND_ASSIGN(EulaHTMLDialog); 97 }; 98 99 } // namespace installer 100 101 #endif // CHROME_INSTALLER_UTIL_HTML_DIALOG_H_ 102