![electron-roller[bot]](/assets/img/avatar_default.png)
* chore: bump chromium in DEPS to 121.0.6128.0 * build: update patches * refactor: remove instrumentation from extensions code Ref:5002404
* refactor: modernization of tabs_api Ref:4997031
* fix: add RecordHover and RecordDrag handlers * build: add missing pdf files * chore: bump chromium in DEPS to 121.0.6129.0 * chore: bump chromium in DEPS to 121.0.6131.0 * chore: update patches * refactor: remove will_cause_resize from ExitFullscreen Ref:5031312
* chore: add missing std converter include Before these were being inferred as std::string implicitly, not anymore Ref:5029573
* chore: Unwrap UserScriptList from unique_ptrs Ref:5005198
* refactor: add PDF internal id into PDF stream info Ref:4876972
* refactor: add metadata to view classes Ref:4994885
* chore: run lint --fix * chore: update libc++ filenames * chore: clean up menubar * chore: update patches after main merge * 5010979: Replace base::WStringPiece usage with std::wstring_view |5010979
* chore: bump chromium in DEPS to 121.0.6142.0 * chore: update patches * 4969574: Refactor NativeDesktopMediaList |4969574
* 5031192: [blink] Create new blink test suite that doesn't create blink Isolate |5031192
* chore: update v8/devtools patches * 5040722: [base] Replace MakeFixedFlatTreeSorted with tag type overloads |5040722
* 5026474: Add --generate-pdf-document-outline |5026474
* 5024297: Change parameter of CheckMediaAccessPermission from GURL to URL::Origin |5024297
* 5034217: [RWS] Remove CanonicalCookie::IsSameParty method |5034217
* 5037192: Rewrite usage of RenderFrame::GetRoutingID |5037192
* 5041802: Reland "Incorporate policy override for OOPPD feature" |5041802
* chore: bump chromium in DEPS to 121.0.6143.0 * chore: bump chromium in DEPS to 121.0.6145.0 * chore: update chromium patches * 5049986: Use std::unique_ptr for MenuItemView::submenu_ member. |5049986
* 5041595: picture-in-picture: Add PictureInPictureOcclusionTracker |5041595
* chore: update all patches * chore: bump chromium in DEPS to 121.0.6147.0 * chore: update patches * 5051069: Use base::FunctionRef for BrowserPluginGuestManager. |5051069
* 5057330: [base] Remove base::Erase()/base::EraseIf() overloads for std::set |5057330
* fixup! 5041802: Reland "Incorporate policy override for OOPPD feature" |5041802
* 5017518: Remove PPAPI if NaCl is disabled |5017518
* 5002232: [DevTools] Console Insights: move from build flag to Feature API |5002232
* 4970322: [X11] Move utils into x11::Connection |4970322
* 5048950: Let MenuModelAdapter::CreateMenu return a std::unique_ptr<>. |5048950
* chore: update libcxx filenames * use Context::Scope in RunScriptsAtDocument{Start,End} * 4775128: content: Reuse CC instance for main frame navigations4775128
* also wrap WebWorkerObserver::ContextWillDestroy with Context::Scope * set LIBCPP_HARDENING_MODE5014271
--------- Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com> Co-authored-by: Samuel Attard <marshallofsound@electronjs.org> Co-authored-by: Keeley Hammond <vertedinde@electronjs.org> Co-authored-by: VerteDinde <keeleymhammond@gmail.com> Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com> Co-authored-by: Jeremy Rose <jeremya@chromium.org>
102 lines
3.4 KiB
C++
102 lines
3.4 KiB
C++
// Copyright (c) 2014 GitHub, Inc.
|
|
// Use of this source code is governed by the MIT license that can be
|
|
// found in the LICENSE file.
|
|
|
|
#include "shell/browser/ui/views/submenu_button.h"
|
|
|
|
#include "base/strings/string_util.h"
|
|
#include "base/strings/utf_string_conversions.h"
|
|
#include "ui/accessibility/ax_enums.mojom.h"
|
|
#include "ui/gfx/canvas.h"
|
|
#include "ui/gfx/color_utils.h"
|
|
#include "ui/gfx/text_utils.h"
|
|
#include "ui/views/animation/flood_fill_ink_drop_ripple.h"
|
|
#include "ui/views/animation/ink_drop_host.h"
|
|
#include "ui/views/animation/ink_drop_impl.h"
|
|
#include "ui/views/controls/button/label_button_border.h"
|
|
|
|
namespace electron {
|
|
|
|
SubmenuButton::SubmenuButton(PressedCallback callback,
|
|
const std::u16string& title,
|
|
const SkColor& background_color)
|
|
: views::MenuButton(callback, gfx::RemoveAccelerator(title)),
|
|
background_color_(background_color) {
|
|
#if BUILDFLAG(IS_LINUX)
|
|
// Dont' use native style border.
|
|
SetBorder(CreateDefaultBorder());
|
|
#endif
|
|
|
|
if (GetUnderlinePosition(title, &accelerator_, &underline_start_,
|
|
&underline_end_))
|
|
gfx::Canvas::SizeStringInt(GetText(), gfx::FontList(), &text_width_,
|
|
&text_height_, 0, 0);
|
|
|
|
views::InkDropHost* ink_drop = views::InkDrop::Get(this);
|
|
ink_drop->SetMode(views::InkDropHost::InkDropMode::ON);
|
|
ink_drop->SetBaseColor(
|
|
color_utils::BlendTowardMaxContrast(background_color_, 0x81));
|
|
views::InkDrop::UseInkDropForFloodFillRipple(ink_drop, false, true);
|
|
}
|
|
|
|
SubmenuButton::~SubmenuButton() = default;
|
|
|
|
void SubmenuButton::SetAcceleratorVisibility(bool visible) {
|
|
if (visible == show_underline_)
|
|
return;
|
|
|
|
show_underline_ = visible;
|
|
SchedulePaint();
|
|
}
|
|
|
|
void SubmenuButton::SetUnderlineColor(SkColor color) {
|
|
underline_color_ = color;
|
|
}
|
|
|
|
void SubmenuButton::GetAccessibleNodeData(ui::AXNodeData* node_data) {
|
|
node_data->role = ax::mojom::Role::kPopUpButton;
|
|
node_data->SetName(GetAccessibleName());
|
|
}
|
|
|
|
void SubmenuButton::PaintButtonContents(gfx::Canvas* canvas) {
|
|
views::MenuButton::PaintButtonContents(canvas);
|
|
|
|
if (show_underline_ && (underline_start_ != underline_end_)) {
|
|
float padding = (width() - text_width_) / 2;
|
|
float underline_height = (height() + text_height_) / 2 - 2;
|
|
canvas->DrawSharpLine(
|
|
gfx::PointF(underline_start_ + padding, underline_height),
|
|
gfx::PointF(underline_end_ + padding, underline_height),
|
|
underline_color_);
|
|
}
|
|
}
|
|
|
|
bool SubmenuButton::GetUnderlinePosition(const std::u16string& text,
|
|
char16_t* accelerator,
|
|
int* start,
|
|
int* end) const {
|
|
int pos, span;
|
|
std::u16string trimmed =
|
|
gfx::LocateAndRemoveAcceleratorChar(text, &pos, &span);
|
|
if (pos > -1 && span != 0) {
|
|
*accelerator = base::ToUpperASCII(trimmed[pos]);
|
|
GetCharacterPosition(trimmed, pos, start);
|
|
GetCharacterPosition(trimmed, pos + span, end);
|
|
return true;
|
|
}
|
|
|
|
return false;
|
|
}
|
|
|
|
void SubmenuButton::GetCharacterPosition(const std::u16string& text,
|
|
int index,
|
|
int* pos) const {
|
|
int height = 0;
|
|
gfx::Canvas::SizeStringInt(text.substr(0, index), gfx::FontList(), pos,
|
|
&height, 0, 0);
|
|
}
|
|
|
|
BEGIN_METADATA(SubmenuButton)
|
|
END_METADATA
|
|
|
|
} // namespace electron
|