mirror of
https://bitbucket.org/chromiumembedded/cef
synced 2025-01-22 15:29:56 +01:00
150 lines
4.5 KiB
C++
150 lines
4.5 KiB
C++
// Copyright (c) 2012 The Chromium Embedded Framework Authors. All rights
|
|
// reserved. Use of this source code is governed by a BSD-style license that
|
|
// can be found in the LICENSE file.
|
|
|
|
#include "libcef/browser/context_menu_params_impl.h"
|
|
|
|
#include "base/logging.h"
|
|
#include "third_party/blink/public/mojom/context_menu/context_menu.mojom.h"
|
|
|
|
CefContextMenuParamsImpl::CefContextMenuParamsImpl(
|
|
content::ContextMenuParams* value)
|
|
: CefValueBase<CefContextMenuParams, content::ContextMenuParams>(
|
|
value,
|
|
nullptr,
|
|
kOwnerNoDelete,
|
|
true,
|
|
new CefValueControllerNonThreadSafe()) {
|
|
// Indicate that this object owns the controller.
|
|
SetOwnsController();
|
|
}
|
|
|
|
int CefContextMenuParamsImpl::GetXCoord() {
|
|
CEF_VALUE_VERIFY_RETURN(false, 0);
|
|
return const_value().x;
|
|
}
|
|
|
|
int CefContextMenuParamsImpl::GetYCoord() {
|
|
CEF_VALUE_VERIFY_RETURN(false, 0);
|
|
return const_value().y;
|
|
}
|
|
|
|
CefContextMenuParamsImpl::TypeFlags CefContextMenuParamsImpl::GetTypeFlags() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CM_TYPEFLAG_NONE);
|
|
const content::ContextMenuParams& params = const_value();
|
|
int type_flags = CM_TYPEFLAG_NONE;
|
|
if (!params.page_url.is_empty())
|
|
type_flags |= CM_TYPEFLAG_PAGE;
|
|
if (!params.frame_url.is_empty())
|
|
type_flags |= CM_TYPEFLAG_FRAME;
|
|
if (!params.link_url.is_empty())
|
|
type_flags |= CM_TYPEFLAG_LINK;
|
|
if (params.media_type != blink::mojom::ContextMenuDataMediaType::kNone)
|
|
type_flags |= CM_TYPEFLAG_MEDIA;
|
|
if (!params.selection_text.empty())
|
|
type_flags |= CM_TYPEFLAG_SELECTION;
|
|
if (params.is_editable)
|
|
type_flags |= CM_TYPEFLAG_EDITABLE;
|
|
return static_cast<TypeFlags>(type_flags);
|
|
}
|
|
|
|
CefString CefContextMenuParamsImpl::GetLinkUrl() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CefString());
|
|
return const_value().link_url.spec();
|
|
}
|
|
|
|
CefString CefContextMenuParamsImpl::GetUnfilteredLinkUrl() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CefString());
|
|
return const_value().unfiltered_link_url.spec();
|
|
}
|
|
|
|
CefString CefContextMenuParamsImpl::GetSourceUrl() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CefString());
|
|
return const_value().src_url.spec();
|
|
}
|
|
|
|
bool CefContextMenuParamsImpl::HasImageContents() {
|
|
CEF_VALUE_VERIFY_RETURN(false, true);
|
|
return const_value().has_image_contents;
|
|
}
|
|
|
|
CefString CefContextMenuParamsImpl::GetTitleText() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CefString());
|
|
return const_value().title_text;
|
|
}
|
|
|
|
CefString CefContextMenuParamsImpl::GetPageUrl() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CefString());
|
|
return const_value().page_url.spec();
|
|
}
|
|
|
|
CefString CefContextMenuParamsImpl::GetFrameUrl() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CefString());
|
|
return const_value().frame_url.spec();
|
|
}
|
|
|
|
CefString CefContextMenuParamsImpl::GetFrameCharset() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CefString());
|
|
return const_value().frame_charset;
|
|
}
|
|
|
|
CefContextMenuParamsImpl::MediaType CefContextMenuParamsImpl::GetMediaType() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CM_MEDIATYPE_NONE);
|
|
return static_cast<MediaType>(const_value().media_type);
|
|
}
|
|
|
|
CefContextMenuParamsImpl::MediaStateFlags
|
|
CefContextMenuParamsImpl::GetMediaStateFlags() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CM_MEDIAFLAG_NONE);
|
|
return static_cast<MediaStateFlags>(const_value().media_flags);
|
|
}
|
|
|
|
CefString CefContextMenuParamsImpl::GetSelectionText() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CefString());
|
|
return const_value().selection_text;
|
|
}
|
|
|
|
CefString CefContextMenuParamsImpl::GetMisspelledWord() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CefString());
|
|
return const_value().misspelled_word;
|
|
}
|
|
|
|
bool CefContextMenuParamsImpl::GetDictionarySuggestions(
|
|
std::vector<CefString>& suggestions) {
|
|
CEF_VALUE_VERIFY_RETURN(false, false);
|
|
|
|
if (!suggestions.empty())
|
|
suggestions.clear();
|
|
|
|
if (const_value().dictionary_suggestions.empty())
|
|
return false;
|
|
|
|
std::vector<std::u16string>::const_iterator it =
|
|
const_value().dictionary_suggestions.begin();
|
|
for (; it != const_value().dictionary_suggestions.end(); ++it)
|
|
suggestions.push_back(*it);
|
|
|
|
return true;
|
|
}
|
|
|
|
bool CefContextMenuParamsImpl::IsEditable() {
|
|
CEF_VALUE_VERIFY_RETURN(false, false);
|
|
return const_value().is_editable;
|
|
}
|
|
|
|
bool CefContextMenuParamsImpl::IsSpellCheckEnabled() {
|
|
CEF_VALUE_VERIFY_RETURN(false, false);
|
|
return const_value().spellcheck_enabled;
|
|
}
|
|
|
|
CefContextMenuParamsImpl::EditStateFlags
|
|
CefContextMenuParamsImpl::GetEditStateFlags() {
|
|
CEF_VALUE_VERIFY_RETURN(false, CM_EDITFLAG_NONE);
|
|
return static_cast<EditStateFlags>(const_value().edit_flags);
|
|
}
|
|
|
|
bool CefContextMenuParamsImpl::IsCustomMenu() {
|
|
CEF_VALUE_VERIFY_RETURN(false, false);
|
|
return !const_value().custom_items.empty();
|
|
}
|