Skip to content

Commit

Permalink
Wrap clean link to a feature flag (#17673)
Browse files Browse the repository at this point in the history
  • Loading branch information
spylogsster authored Mar 21, 2023
1 parent ca563b0 commit 002f825
Show file tree
Hide file tree
Showing 6 changed files with 96 additions and 13 deletions.
9 changes: 9 additions & 0 deletions browser/about_flags.cc
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@

#include <initializer_list>

#include "brave/browser/brave_browser_features.h"
#include "brave/browser/brave_features_internal_names.h"
#include "brave/browser/ethereum_remote_client/buildflags/buildflags.h"
#include "brave/browser/ethereum_remote_client/features.h"
Expand Down Expand Up @@ -704,6 +705,14 @@
kOsAll, \
FEATURE_VALUE_TYPE(brave_sync::features::kBraveSyncSendAllHistory), \
}, \
{ \
"brave-copy-clean-link-by-default", \
"Override default copy hotkey with copy clean link", \
"Sanitize url before copying, replaces default ctrl+c hotkey for " \
"url ", \
kOsWin | kOsLinux | kOsMac, \
FEATURE_VALUE_TYPE(features::kBraveCopyCleanLinkByDefault), \
}, \
{ \
"https-by-default", \
"Use HTTPS by Default", \
Expand Down
7 changes: 6 additions & 1 deletion browser/brave_app_controller_mac.mm
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@
#import "brave/browser/brave_app_controller_mac.h"

#include "brave/app/brave_command_ids.h"
#include "brave/browser/brave_browser_features.h"
#include "brave/browser/ui/browser_commands.h"
#include "chrome/app/chrome_command_ids.h"
#include "chrome/browser/ui/browser.h"
Expand Down Expand Up @@ -60,7 +61,11 @@ - (void)menuNeedsUpdate:(NSMenu*)menu {
}
if ([self shouldShowCleanLinkItem]) {
[_copyCleanLinkMenuItem setHidden:NO];
[self setKeyEquivalentToItem:_copyCleanLinkMenuItem];
if (base::FeatureList::IsEnabled(features::kBraveCopyCleanLinkByDefault)) {
[self setKeyEquivalentToItem:_copyCleanLinkMenuItem];
} else {
[self setKeyEquivalentToItem:_copyMenuItem];
}
} else {
[_copyCleanLinkMenuItem setHidden:YES];
[self setKeyEquivalentToItem:_copyMenuItem];
Expand Down
54 changes: 54 additions & 0 deletions browser/brave_app_controller_mac_browsertest.mm
Original file line number Diff line number Diff line change
Expand Up @@ -13,8 +13,10 @@
#include "base/mac/foundation_util.h"
#include "base/mac/scoped_nsobject.h"
#include "base/mac/scoped_objc_class_swizzler.h"
#include "base/test/scoped_feature_list.h"
#include "brave/app/brave_command_ids.h"
#include "brave/browser/brave_app_controller_mac.h"
#include "brave/browser/brave_browser_features.h"
#include "brave/browser/ui/views/frame/brave_browser_view.h"
#include "chrome/app/chrome_command_ids.h"
#include "chrome/browser/ui/browser.h"
Expand All @@ -32,6 +34,58 @@

using BraveAppControllerBrowserTest = InProcessBrowserTest;

class BraveAppControllerCleanLinkFeatureDisabledBrowserTest
: public InProcessBrowserTest {
public:
BraveAppControllerCleanLinkFeatureDisabledBrowserTest() {
features_.InitWithFeatureState(features::kBraveCopyCleanLinkByDefault,
false);
}

private:
base::test::ScopedFeatureList features_;
};

IN_PROC_BROWSER_TEST_F(BraveAppControllerCleanLinkFeatureDisabledBrowserTest,
CopyLinkItemVisible) {
ASSERT_TRUE(embedded_test_server()->Start());
GURL url = embedded_test_server()->GetURL(kTestingPage);
ASSERT_TRUE(ui_test_utils::NavigateToURL(browser(), url));
EXPECT_EQ(1u, chrome::GetTotalBrowserCount());

BraveBrowserView* browser_view = static_cast<BraveBrowserView*>(
BraveBrowserView::GetBrowserViewForBrowser(browser()));
OmniboxView* omnibox_view = browser_view->GetLocationBar()->GetOmniboxView();
omnibox_view->SetFocus(true);
omnibox_view->SelectAll(false);
EXPECT_TRUE(omnibox_view->IsSelectAll());
EXPECT_TRUE(BraveBrowserWindow::From(browser()->window())->HasSelectedURL());

BraveAppController* ac = base::mac::ObjCCastStrict<BraveAppController>(
[[NSApplication sharedApplication] delegate]);
ASSERT_TRUE(ac);
base::scoped_nsobject<NSMenu> edit_submenu(
[[[NSApp mainMenu] itemWithTag:IDC_EDIT_MENU] submenu],
base::scoped_policy::RETAIN);

base::scoped_nsobject<NSMenuItem> copy_item(
[edit_submenu itemWithTag:IDC_CONTENT_CONTEXT_COPY],
base::scoped_policy::RETAIN);

base::scoped_nsobject<NSMenuItem> clean_link_menu_item(
[edit_submenu itemWithTag:IDC_COPY_CLEAN_LINK],
base::scoped_policy::RETAIN);

[ac menuNeedsUpdate:[clean_link_menu_item menu]];
base::RunLoop().RunUntilIdle();
EXPECT_FALSE([clean_link_menu_item isHidden]);

EXPECT_TRUE([[clean_link_menu_item keyEquivalent] isEqualToString:@""]);

EXPECT_TRUE([[copy_item keyEquivalent] isEqualToString:@"c"]);
EXPECT_EQ([copy_item keyEquivalentModifierMask], NSEventModifierFlagCommand);
}

IN_PROC_BROWSER_TEST_F(BraveAppControllerBrowserTest, CopyLinkItemVisible) {
ASSERT_TRUE(embedded_test_server()->Start());
GURL url = embedded_test_server()->GetURL(kTestingPage);
Expand Down
5 changes: 5 additions & 0 deletions browser/brave_browser_features.cc
Original file line number Diff line number Diff line change
Expand Up @@ -12,4 +12,9 @@ BASE_FEATURE(kBraveCleanupSessionCookiesOnSessionRestore,
"BraveCleanupSessionCookiesOnSessionRestore",
base::FEATURE_ENABLED_BY_DEFAULT);

// Sanitize url before copying, replaces default ctrl+c hotkey for urls.
BASE_FEATURE(kBraveCopyCleanLinkByDefault,
"brave-copy-clean-link-by-default",
base::FEATURE_ENABLED_BY_DEFAULT);

} // namespace features
1 change: 1 addition & 0 deletions browser/brave_browser_features.h
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
namespace features {

BASE_DECLARE_FEATURE(kBraveCleanupSessionCookiesOnSessionRestore);
BASE_DECLARE_FEATURE(kBraveCopyCleanLinkByDefault);

} // namespace features

Expand Down
33 changes: 21 additions & 12 deletions browser/ui/views/omnibox/brave_omnibox_view_views.cc
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
#include <utility>

#include "brave/app/brave_command_ids.h"
#include "brave/browser/brave_browser_features.h"
#include "brave/browser/ui/browser_commands.h"
#include "chrome/browser/ui/browser.h"
#include "chrome/browser/ui/browser_finder.h"
Expand Down Expand Up @@ -63,6 +64,10 @@ void BraveOmniboxViewViews::CopySanitizedURL(const GURL& url) {
#if BUILDFLAG(IS_WIN)
bool BraveOmniboxViewViews::AcceleratorPressed(
const ui::Accelerator& accelerator) {
if (!base::FeatureList::IsEnabled(features::kBraveCopyCleanLinkByDefault)) {
return OmniboxViewViews::AcceleratorPressed(accelerator);
}

ui::KeyEvent event(
accelerator.key_state() == ui::Accelerator::KeyState::PRESSED
? ui::ET_KEY_PRESSED
Expand All @@ -85,14 +90,16 @@ bool BraveOmniboxViewViews::AcceleratorPressed(
bool BraveOmniboxViewViews::GetAcceleratorForCommandId(
int command_id,
ui::Accelerator* accelerator) const {
bool is_url = const_cast<BraveOmniboxViewViews*>(this)->SelectedTextIsURL();
if (is_url) {
if (command_id == kCopy) {
return false;
}
if (command_id == IDC_COPY_CLEAN_LINK) {
*accelerator = ui::Accelerator(ui::VKEY_C, ui::EF_PLATFORM_ACCELERATOR);
return true;
if (base::FeatureList::IsEnabled(features::kBraveCopyCleanLinkByDefault)) {
bool is_url = const_cast<BraveOmniboxViewViews*>(this)->SelectedTextIsURL();
if (is_url) {
if (command_id == kCopy) {
return false;
}
if (command_id == IDC_COPY_CLEAN_LINK) {
*accelerator = ui::Accelerator(ui::VKEY_C, ui::EF_PLATFORM_ACCELERATOR);
return true;
}
}
}
return OmniboxViewViews::GetAcceleratorForCommandId(command_id, accelerator);
Expand All @@ -101,10 +108,12 @@ bool BraveOmniboxViewViews::GetAcceleratorForCommandId(
#if BUILDFLAG(IS_LINUX) || BUILDFLAG(IS_MAC)
void BraveOmniboxViewViews::ExecuteTextEditCommand(
ui::TextEditCommand command) {
auto url_to_copy = GetURLToCopy();
if (command == ui::TextEditCommand::COPY && url_to_copy.has_value()) {
CopySanitizedURL(url_to_copy.value());
return;
if (base::FeatureList::IsEnabled(features::kBraveCopyCleanLinkByDefault)) {
auto url_to_copy = GetURLToCopy();
if (command == ui::TextEditCommand::COPY && url_to_copy.has_value()) {
CopySanitizedURL(url_to_copy.value());
return;
}
}
OmniboxViewViews::ExecuteTextEditCommand(command);
}
Expand Down

0 comments on commit 002f825

Please sign in to comment.