
- Add popup dialog support for JavaScript alert/confirm/prompt fuctions on content shell GTK port. BUG=90445,138603 TEST= TBR=jam@chromium.org Review URL: https://chromiumcodereview.appspot.com/10824077 git-svn-id: svn://svn.chromium.org/chrome/trunk/src@149019 0039d316-1c4b-4281-b951-d872f2087c98
66 lines
2.0 KiB
C++
66 lines
2.0 KiB
C++
// Copyright (c) 2012 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.
|
|
|
|
#ifndef CONTENT_SHELL_SHELL_JAVASCRIPT_DIALOG_CREATOR_H_
|
|
#define CONTENT_SHELL_SHELL_JAVASCRIPT_DIALOG_CREATOR_H_
|
|
|
|
#include "base/compiler_specific.h"
|
|
#include "base/callback_forward.h"
|
|
#include "base/memory/scoped_ptr.h"
|
|
#include "content/public/browser/javascript_dialogs.h"
|
|
|
|
namespace content {
|
|
|
|
class ShellJavaScriptDialog;
|
|
|
|
class ShellJavaScriptDialogCreator : public JavaScriptDialogCreator {
|
|
public:
|
|
ShellJavaScriptDialogCreator();
|
|
virtual ~ShellJavaScriptDialogCreator();
|
|
|
|
// JavaScriptDialogCreator:
|
|
virtual void RunJavaScriptDialog(
|
|
WebContents* web_contents,
|
|
const GURL& origin_url,
|
|
const std::string& accept_lang,
|
|
JavaScriptMessageType javascript_message_type,
|
|
const string16& message_text,
|
|
const string16& default_prompt_text,
|
|
const DialogClosedCallback& callback,
|
|
bool* did_suppress_message) OVERRIDE;
|
|
|
|
virtual void RunBeforeUnloadDialog(
|
|
WebContents* web_contents,
|
|
const string16& message_text,
|
|
bool is_reload,
|
|
const DialogClosedCallback& callback) OVERRIDE;
|
|
|
|
virtual void ResetJavaScriptState(WebContents* web_contents) OVERRIDE;
|
|
|
|
// Called by the ShellJavaScriptDialog when it closes.
|
|
void DialogClosed(ShellJavaScriptDialog* dialog);
|
|
|
|
// Used for content_browsertests.
|
|
void set_dialog_request_callback(
|
|
base::Callback<void()> dialog_request_callback) {
|
|
dialog_request_callback_ = dialog_request_callback;
|
|
}
|
|
|
|
private:
|
|
#if defined(OS_MACOSX) || defined(OS_WIN) || defined(TOOLKIT_GTK)
|
|
// The dialog being shown. No queueing.
|
|
scoped_ptr<ShellJavaScriptDialog> dialog_;
|
|
#else
|
|
// TODO: implement ShellJavaScriptDialog for other platforms, drop this #if
|
|
#endif
|
|
|
|
base::Callback<void()> dialog_request_callback_;
|
|
|
|
DISALLOW_COPY_AND_ASSIGN(ShellJavaScriptDialogCreator);
|
|
};
|
|
|
|
} // namespace content
|
|
|
|
#endif // CONTENT_SHELL_SHELL_JAVASCRIPT_DIALOG_CREATOR_H_
|