blob: 4bfc286c231e632ea6f179703345ddc991ff469f (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
|
// Copyright (c) 2006-2008 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 CHROME_BROWSER_JSMESSAGE_BOX_HANDLER_WIN_H_
#define CHROME_BROWSER_JSMESSAGE_BOX_HANDLER_WIN_H_
#include "chrome/browser/jsmessage_box_handler.h"
#include "chrome/common/ipc_message.h"
#include "chrome/common/notification_observer.h"
#include "chrome/common/notification_registrar.h"
#include "chrome/views/app_modal_dialog_delegate.h"
#include "googleurl/src/gurl.h"
class MessageBoxView;
class WebContents;
namespace views {
class Window;
}
class JavascriptMessageBoxHandler
: public views::AppModalDialogDelegate,
public NotificationObserver {
public:
// Cross-platform code should use RunJavaScriptMessageBox.
JavascriptMessageBoxHandler(WebContents* web_contents,
const GURL& frame_url,
int dialog_flags,
const std::wstring& message_text,
const std::wstring& default_prompt_text,
bool display_suppress_checkbox,
IPC::Message* reply_msg);
virtual ~JavascriptMessageBoxHandler();
// views::DialogDelegate Methods:
virtual int GetDialogButtons() const;
virtual std::wstring GetWindowTitle() const;
virtual void WindowClosing();
virtual void DeleteDelegate();
virtual bool Cancel();
virtual bool Accept();
// views::AppModalDialogDelegate
virtual void ShowModalDialog();
virtual void ActivateModalDialog();
// views::WindowDelegate Methods:
virtual bool IsModal() const { return true; }
virtual views::View* GetContentsView();
virtual views::View* GetInitiallyFocusedView();
private:
// NotificationObserver implementation.
virtual void Observe(NotificationType type,
const NotificationSource& source,
const NotificationDetails& details);
NotificationRegistrar registrar_;
// The message box view whose commands we handle.
MessageBoxView* message_box_view_;
// The IPC message used to reply to the renderer when the message box
// is dismissed.
IPC::Message* reply_msg_;
// The associated WebContents. Used to send IPC messages to the renderer.
WebContents* web_contents_;
// The URL of the frame originating the dialog. It is important we display
// this so the user doesn't blame the enclosing site if a subframe alert()s.
GURL frame_url_;
// Stores flags defined in message_box_view.h which describe the dialog box.
int dialog_flags_;
// The dialog if it is currently visible.
views::Window* dialog_;
DISALLOW_COPY_AND_ASSIGN(JavascriptMessageBoxHandler);
};
#endif // CHROME_BROWSER_JSMESSAGE_BOX_HANDLER_WIN_H_
|