Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(344)

Side by Side Diff: chrome/browser/geolocation/geolocation_infobar_delegate.h

Issue 441883003: Simplify Android geolocation permission checks (Closed) Base URL: svn://svn.chromium.org/chrome/trunk/src
Patch Set: Bernhard review, fix tests Created 6 years, 4 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View unified diff | Download patch | Annotate | Revision Log
OLDNEW
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. 1 // Copyright 2012 The Chromium Authors. All rights reserved.
2 // Use of this source code is governed by a BSD-style license that can be 2 // Use of this source code is governed by a BSD-style license that can be
3 // found in the LICENSE file. 3 // found in the LICENSE file.
4 4
5 #ifndef CHROME_BROWSER_GEOLOCATION_GEOLOCATION_INFOBAR_DELEGATE_H_ 5 #ifndef CHROME_BROWSER_GEOLOCATION_GEOLOCATION_INFOBAR_DELEGATE_H_
6 #define CHROME_BROWSER_GEOLOCATION_GEOLOCATION_INFOBAR_DELEGATE_H_ 6 #define CHROME_BROWSER_GEOLOCATION_GEOLOCATION_INFOBAR_DELEGATE_H_
7 7
8 #include <string> 8 #include <string>
9 9
10 #include "chrome/browser/content_settings/permission_request_id.h" 10 #include "chrome/browser/content_settings/permission_request_id.h"
11 #include "components/infobars/core/confirm_infobar_delegate.h" 11 #include "components/infobars/core/confirm_infobar_delegate.h"
12 #include "url/gurl.h" 12 #include "url/gurl.h"
13 13
14 class PermissionQueueController; 14 class PermissionQueueController;
15 class InfoBarService; 15 class InfoBarService;
16 16
17 // GeolocationInfoBarDelegates are created by the 17 // GeolocationInfoBarDelegates are created by the
18 // GeolocationInfoBarQueueController to control the display 18 // GeolocationInfoBarQueueController to control the display
19 // and handling of geolocation permission infobars to the user. 19 // and handling of geolocation permission infobars to the user.
20 class GeolocationInfoBarDelegate : public ConfirmInfoBarDelegate { 20 class GeolocationInfoBarDelegate : public ConfirmInfoBarDelegate {
21 public: 21 public:
22 // Creates a geolocation infobar and delegate and adds the infobar to 22 // Creates a geolocation infobar and delegate and adds the infobar to
23 // |infobar_service|. Returns the infobar if it was successfully added. 23 // |infobar_service|. Returns the infobar if it was successfully added.
24 static infobars::InfoBar* Create(InfoBarService* infobar_service, 24 static infobars::InfoBar* Create(InfoBarService* infobar_service,
25 PermissionQueueController* controller, 25 PermissionQueueController* controller,
26 const PermissionRequestID& id, 26 const PermissionRequestID& id,
27 const GURL& requesting_frame, 27 const GURL& requesting_frame,
28 const std::string& display_languages, 28 const std::string& display_languages);
29 const std::string& accept_button_label);
30 29
31 protected: 30 private:
32 GeolocationInfoBarDelegate(PermissionQueueController* controller, 31 GeolocationInfoBarDelegate(PermissionQueueController* controller,
33 const PermissionRequestID& id, 32 const PermissionRequestID& id,
34 const GURL& requesting_frame, 33 const GURL& requesting_frame,
35 int contents_unique_id, 34 int contents_unique_id,
36 const std::string& display_languages, 35 const std::string& display_languages);
37 const std::string& accept_button_label);
38 virtual ~GeolocationInfoBarDelegate(); 36 virtual ~GeolocationInfoBarDelegate();
39 37
38
Michael van Ouwerkerk 2014/08/06 10:47:44 Nit: why two lines of ws?
Miguel Garcia 2014/08/06 12:56:58 Removed one
40 // ConfirmInfoBarDelegate: 39 // ConfirmInfoBarDelegate:
41 virtual bool Accept() OVERRIDE; 40 virtual bool Accept() OVERRIDE;
42
43 // Call back to the controller, to inform of the user's decision.
44 void SetPermission(bool update_content_setting, bool allowed);
45
46 // Marks a flag internally to indicate that the user has interacted with the
47 // bar. This makes it possible to log from the destructor when the bar has not
48 // been used, i.e. it has been ignored by the user.
49 void set_user_has_interacted() {
50 user_has_interacted_ = true;
51 }
52
53 private:
54 // ConfirmInfoBarDelegate:
55 virtual void InfoBarDismissed() OVERRIDE; 41 virtual void InfoBarDismissed() OVERRIDE;
56 virtual int GetIconID() const OVERRIDE; 42 virtual int GetIconID() const OVERRIDE;
57 virtual Type GetInfoBarType() const OVERRIDE; 43 virtual Type GetInfoBarType() const OVERRIDE;
58 virtual bool ShouldExpireInternal( 44 virtual bool ShouldExpireInternal(
59 const NavigationDetails& details) const OVERRIDE; 45 const NavigationDetails& details) const OVERRIDE;
60 virtual base::string16 GetMessageText() const OVERRIDE; 46 virtual base::string16 GetMessageText() const OVERRIDE;
61 virtual base::string16 GetButtonLabel(InfoBarButton button) const OVERRIDE; 47 virtual base::string16 GetButtonLabel(InfoBarButton button) const OVERRIDE;
62 virtual bool Cancel() OVERRIDE; 48 virtual bool Cancel() OVERRIDE;
63 virtual base::string16 GetLinkText() const OVERRIDE; 49 virtual base::string16 GetLinkText() const OVERRIDE;
64 virtual bool LinkClicked(WindowOpenDisposition disposition) OVERRIDE; 50 virtual bool LinkClicked(WindowOpenDisposition disposition) OVERRIDE;
65 51
52
53 // Call back to the controller, to inform of the user's decision.
54 void SetPermission(bool update_content_setting, bool allowed);
55
56 // Marks a flag internally to indicate that the user has interacted with the
57 // bar. This makes it possible to log from the destructor when the bar has not
58 // been used, i.e. it has been ignored by the user.
59 void set_user_has_interacted() {
60 user_has_interacted_ = true;
61 }
62
66 PermissionQueueController* controller_; 63 PermissionQueueController* controller_;
67 const PermissionRequestID id_; 64 const PermissionRequestID id_;
68 GURL requesting_frame_; 65 GURL requesting_frame_;
69 int contents_unique_id_; 66 int contents_unique_id_;
70 std::string display_languages_; 67 std::string display_languages_;
71 68
72 // Whether the user has interacted with the geolocation infobar. 69 // Whether the user has interacted with the geolocation infobar.
73 bool user_has_interacted_; 70 bool user_has_interacted_;
74 71
75 DISALLOW_COPY_AND_ASSIGN(GeolocationInfoBarDelegate); 72 DISALLOW_COPY_AND_ASSIGN(GeolocationInfoBarDelegate);
76 }; 73 };
77 74
78 #endif // CHROME_BROWSER_GEOLOCATION_GEOLOCATION_INFOBAR_DELEGATE_H_ 75 #endif // CHROME_BROWSER_GEOLOCATION_GEOLOCATION_INFOBAR_DELEGATE_H_
OLDNEW

Powered by Google App Engine
This is Rietveld 408576698