1 // Copyright (c) 2012 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 CONTENT_PUBLIC_BROWSER_JAVASCRIPT_DIALOG_MANAGER_H_ 6 #define CONTENT_PUBLIC_BROWSER_JAVASCRIPT_DIALOG_MANAGER_H_ 7 8 #include <string> 9 10 #include "base/callback.h" 11 #include "base/strings/string16.h" 12 #include "content/common/content_export.h" 13 #include "content/public/common/javascript_message_type.h" 14 #include "ui/gfx/native_widget_types.h" 15 #include "url/gurl.h" 16 17 namespace content { 18 19 class WebContents; 20 21 // An interface consisting of methods that can be called to produce and manage 22 // JavaScript dialogs. 23 class CONTENT_EXPORT JavaScriptDialogManager { 24 public: 25 typedef base::Callback<void(bool /* success */, 26 const base::string16& /* user_input */)> 27 DialogClosedCallback; 28 29 // Displays a JavaScript dialog. |did_suppress_message| will not be nil; if 30 // |true| is returned in it, the caller will handle faking the reply. 31 virtual void RunJavaScriptDialog( 32 WebContents* web_contents, 33 const GURL& origin_url, 34 const std::string& accept_lang, 35 JavaScriptMessageType javascript_message_type, 36 const base::string16& message_text, 37 const base::string16& default_prompt_text, 38 const DialogClosedCallback& callback, 39 bool* did_suppress_message) = 0; 40 41 // Displays a dialog asking the user if they want to leave a page. 42 virtual void RunBeforeUnloadDialog(WebContents* web_contents, 43 const base::string16& message_text, 44 bool is_reload, 45 const DialogClosedCallback& callback) = 0; 46 47 // Accepts or dismisses the active JavaScript dialog, which must be owned 48 // by the given |web_contents|. If |prompt_override| is not null, the prompt 49 // text of the dialog should be set before accepting. Returns true if the 50 // dialog was handled. 51 virtual bool HandleJavaScriptDialog(WebContents* web_contents, 52 bool accept, 53 const base::string16* prompt_override); 54 55 // Cancels all active and pending dialogs for the given WebContents. 56 virtual void CancelActiveAndPendingDialogs(WebContents* web_contents) = 0; 57 58 // The given WebContents is being destroyed; discards any saved state tied 59 // to it. 60 virtual void WebContentsDestroyed(WebContents* web_contents) = 0; 61 62 virtual ~JavaScriptDialogManager() {} 63 }; 64 65 } // namespace content 66 67 #endif // CONTENT_PUBLIC_BROWSER_JAVASCRIPT_DIALOG_MANAGER_H_ 68