blob: 1d127c4a6f540c6d22970c5a89b144282ff61581 (
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
84
85
86
87
88
89
90
91
92
|
// Copyright (c) 2015 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_UI_EXCLUSIVE_ACCESS_EXCLUSIVE_ACCESS_CONTROLLER_BASE_H_
#define CHROME_BROWSER_UI_EXCLUSIVE_ACCESS_EXCLUSIVE_ACCESS_CONTROLLER_BASE_H_
#include "base/basictypes.h"
#include "base/memory/ref_counted.h"
#include "chrome/browser/ui/exclusive_access/exclusive_access_bubble_type.h"
#include "content/public/browser/notification_observer.h"
#include "content/public/browser/notification_registrar.h"
class ExclusiveAccessManager;
class GURL;
class Profile;
namespace content {
class WebContents;
}
// The base class for the different exclusive access controllers like the
// FullscreenController, and MouseLockController which controls lifetime for
// which the resource (screen/mouse) is held exclusively.
class ExclusiveAccessControllerBase : public content::NotificationObserver {
public:
explicit ExclusiveAccessControllerBase(ExclusiveAccessManager* manager);
~ExclusiveAccessControllerBase() override;
GURL GetExclusiveAccessBubbleURL() const;
virtual GURL GetURLForExclusiveAccessBubble() const;
content::WebContents* exclusive_access_tab() const {
return tab_with_exclusive_access_;
}
// Functions implemented by derived classes:
// Control behavior when escape is pressed returning true if it was handled.
virtual bool HandleUserPressedEscape() = 0;
// Called by Browser in response to call from ExclusiveAccessBubble.
virtual void ExitExclusiveAccessToPreviousState() = 0;
// Called to indicate that the permission for this exclusive access has been
// granted if requested. Returns true if the exit bubble content should be
// updated.
virtual bool OnAcceptExclusiveAccessPermission() = 0;
// Called to indicate that the permission for the exclusive access has been
// denied if requested. Returns true if the exit bubble content should be
// updated.
virtual bool OnDenyExclusiveAccessPermission() = 0;
// Called by ExclusiveAccessManager in response to calls from Browser.
virtual void OnTabDeactivated(content::WebContents* web_contents);
virtual void OnTabDetachedFromView(content::WebContents* web_contents);
virtual void OnTabClosing(content::WebContents* web_contents);
// Callbacks ////////////////////////////////////////////////////////////////
// content::NotificationObserver to detect page navigation and exit exclusive
// access.
void Observe(int type,
const content::NotificationSource& source,
const content::NotificationDetails& details) override;
protected:
void SetTabWithExclusiveAccess(content::WebContents* tab);
ExclusiveAccessManager* exclusive_access_manager() const { return manager_; }
// Exits exclusive access mode for the tab if currently exclusive.
virtual void ExitExclusiveAccessIfNecessary() = 0;
// Notifies the tab that it has been forced out of exclusive access mode
// if necessary.
virtual void NotifyTabExclusiveAccessLost() = 0;
private:
void UpdateNotificationRegistrations();
ExclusiveAccessManager* const manager_;
content::NotificationRegistrar registrar_;
content::WebContents* tab_with_exclusive_access_;
DISALLOW_COPY_AND_ASSIGN(ExclusiveAccessControllerBase);
};
#endif // CHROME_BROWSER_UI_EXCLUSIVE_ACCESS_EXCLUSIVE_ACCESS_CONTROLLER_BASE_H_
|