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 93 94 95 96 97 98 99 100 101 102 103 104 105 106
|
// Copyright 2020 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.
#ifndef CHROME_BROWSER_UI_PAGE_INFO_CHROME_PAGE_INFO_UI_DELEGATE_H_
#define CHROME_BROWSER_UI_PAGE_INFO_CHROME_PAGE_INFO_UI_DELEGATE_H_
#include <string>
#include "base/memory/raw_ptr.h"
#include "base/time/clock.h"
#include "base/time/default_clock.h"
#include "build/build_config.h"
#include "components/page_info/page_info_ui_delegate.h"
#include "url/gurl.h"
#if !BUILDFLAG(IS_ANDROID)
#include "components/page_info/core/proto/about_this_site_metadata.pb.h"
#endif
class Profile;
namespace content {
class WebContents;
}
namespace ui {
class Event;
}
class ChromePageInfoUiDelegate : public PageInfoUiDelegate {
public:
ChromePageInfoUiDelegate(content::WebContents* web_contents,
const GURL& site_url);
~ChromePageInfoUiDelegate() override = default;
// Whether the combobox option for allowing a permission should be shown for
// `type`.
bool ShouldShowAllow(ContentSettingsType type);
// Whether the combobox option to ask a permission should be shown for `type`.
bool ShouldShowAsk(ContentSettingsType type);
// If "allow" option is not available, return the reason why.
std::u16string GetAutomaticallyBlockedReason(ContentSettingsType type);
#if !BUILDFLAG(IS_ANDROID)
// Returns "About this site" info for the active page.
std::optional<page_info::proto::SiteInfo> GetAboutThisSiteInfo();
// Handles opening the "More about this page" URL in a new tab.
void OpenMoreAboutThisPageUrl(const GURL& url, const ui::Event& event);
// If PageInfo should show a link to the site or app's settings page, this
// will return true and set the params to the appropriate resource IDs
// (IDS_*). Otherwise, it will return false.
bool ShouldShowSiteSettings(int* link_text_id, int* tooltip_text_id);
// The returned string, if non-empty, should be added as a sublabel that gives
// extra details to the user concerning the granted permission.
std::u16string GetPermissionDetail(ContentSettingsType type);
// Similar to GetPermissionDetail, if this returns true a sublabel should be
// added to give extra details to the user concerning the granted permission,
// with the difference being that this label includes an embedded link.
// `text_id` should be set to the resource ID for the overall
// label, with `link_id` being inserted into a place holder in the
// description as a clickable link. When the link is clicked,
// SettingsLinkClicked() is called.
bool ShouldShowSettingsLinkForPermission(ContentSettingsType type,
int* text_id,
int* link_id);
// Called when the link specified by ShouldShowSettingsLinkForPermission() is
// clicked.
void SettingsLinkClicked(ContentSettingsType type);
// Opens Privacy Sandbox settings page.
void ShowPrivacySandboxSettings();
// PageInfoUiDelegate implementation
bool IsBlockAutoPlayEnabled() override;
bool IsMultipleTabsOpen() override;
void OpenSiteSettingsFileSystem() override;
void OpenMerchantTrustSidePanel(const GURL& url);
#endif // !BUILDFLAG(IS_ANDROID)
content::PermissionResult GetPermissionResult(
blink::PermissionType permission) override;
std::optional<content::PermissionResult> GetEmbargoResult(
ContentSettingsType type) override;
void GetMerchantTrustInfo(page_info::MerchantDataCallback callback) override;
void RecordPageInfoWithMerchantTrustOpenTime();
void RecordMerchantTrustButtonShown();
void RecordMerchantTrustSidePanelOpened();
private:
Profile* GetProfile() const;
raw_ptr<content::WebContents, AcrossTasksDanglingUntriaged> web_contents_;
GURL site_url_;
raw_ptr<base::Clock> clock_ = base::DefaultClock::GetInstance();
};
#endif // CHROME_BROWSER_UI_PAGE_INFO_CHROME_PAGE_INFO_UI_DELEGATE_H_
|