/*
- * Copyright (c) 2023 Samsung Electronics Co., Ltd.
+ * Copyright (c) 2024 Samsung Electronics Co., Ltd.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
#include <dali/devel-api/adaptor-framework/web-engine/web-engine-load-error.h>
#include <dali/devel-api/adaptor-framework/web-engine/web-engine-policy-decision.h>
#include <dali/devel-api/adaptor-framework/web-engine/web-engine-settings.h>
+#include <dali/devel-api/adaptor-framework/window-devel.h>
#include <dali/devel-api/common/stage.h>
#include <dali/devel-api/scripting/enum-helper.h>
#include <dali/devel-api/scripting/scripting.h>
#include <dali/public-api/object/type-registry.h>
// INTERNAL INCLUDES
+#include <dali-toolkit/devel-api/controls/control-depth-index-ranges.h>
#include <dali-toolkit/devel-api/controls/control-devel.h>
#include <dali-toolkit/devel-api/controls/web-view/web-back-forward-list.h>
#include <dali-toolkit/devel-api/controls/web-view/web-settings.h>
self.WheelEventSignal().Connect(this, &WebView::OnWheelEvent);
Dali::DevelActor::VisibilityChangedSignal(self).Connect(this, &WebView::OnVisibilityChanged);
+ mWebViewVisibleState |= WebViewVisibleStateFlag::SELF_SHOW;
+
mPositionUpdateNotification = self.AddPropertyNotification(Actor::Property::WORLD_POSITION, StepCondition(1.0f, 1.0f));
mSizeUpdateNotification = self.AddPropertyNotification(Actor::Property::SIZE, StepCondition(1.0f, 1.0f));
mScaleUpdateNotification = self.AddPropertyNotification(Actor::Property::WORLD_SCALE, StepCondition(0.1f, 1.0f));
{
if(mWebEngine)
{
- mWebEngine.EvaluateJavaScript(script, resultHandler);
+ mWebEngine.EvaluateJavaScript(script, std::move(resultHandler));
}
}
{
if(mWebEngine)
{
- mWebEngine.AddJavaScriptMessageHandler(exposedObjectName, handler);
+ mWebEngine.AddJavaScriptMessageHandler(exposedObjectName, std::move(handler));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterJavaScriptAlertCallback(callback);
+ mWebEngine.RegisterJavaScriptAlertCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterJavaScriptConfirmCallback(callback);
+ mWebEngine.RegisterJavaScriptConfirmCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterJavaScriptPromptCallback(callback);
+ mWebEngine.RegisterJavaScriptPromptCallback(std::move(callback));
}
}
bool result = false;
if(mWebEngine)
{
- result = mWebEngine.CreateHitTestAsynchronously(x, y, mode, callback);
+ result = mWebEngine.CreateHitTestAsynchronously(x, y, mode, std::move(callback));
}
return result;
}
bool WebView::GetScreenshotAsynchronously(Dali::Rect<int32_t> viewArea, float scaleFactor, Dali::Toolkit::WebView::WebViewScreenshotCapturedCallback callback)
{
- mScreenshotCapturedCallback = callback;
+ mScreenshotCapturedCallback = std::move(callback);
return mWebEngine ? mWebEngine.GetScreenshotAsynchronously(viewArea, scaleFactor, std::bind(&WebView::OnScreenshotCaptured, this, std::placeholders::_1)) : false;
}
bool WebView::CheckVideoPlayingAsynchronously(Dali::WebEnginePlugin::VideoPlayingCallback callback)
{
- return mWebEngine ? mWebEngine.CheckVideoPlayingAsynchronously(callback) : false;
+ return mWebEngine ? mWebEngine.CheckVideoPlayingAsynchronously(std::move(callback)) : false;
}
void WebView::RegisterGeolocationPermissionCallback(Dali::WebEnginePlugin::GeolocationPermissionCallback callback)
{
if(mWebEngine)
{
- mWebEngine.RegisterGeolocationPermissionCallback(callback);
+ mWebEngine.RegisterGeolocationPermissionCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterPageLoadStartedCallback(callback);
+ mWebEngine.RegisterPageLoadStartedCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterPageLoadInProgressCallback(callback);
+ mWebEngine.RegisterPageLoadInProgressCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterPageLoadFinishedCallback(callback);
+ mWebEngine.RegisterPageLoadFinishedCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterPageLoadErrorCallback(callback);
+ mWebEngine.RegisterPageLoadErrorCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterScrollEdgeReachedCallback(callback);
+ mWebEngine.RegisterScrollEdgeReachedCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterUrlChangedCallback(callback);
+ mWebEngine.RegisterUrlChangedCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterFormRepostDecidedCallback(callback);
+ mWebEngine.RegisterFormRepostDecidedCallback(std::move(callback));
}
}
void WebView::RegisterFrameRenderedCallback(Dali::WebEnginePlugin::WebEngineFrameRenderedCallback callback)
{
- mFrameRenderedCallback = callback;
+ mFrameRenderedCallback = std::move(callback);
}
void WebView::RegisterConsoleMessageReceivedCallback(Dali::WebEnginePlugin::WebEngineConsoleMessageReceivedCallback callback)
{
if(mWebEngine)
{
- mWebEngine.RegisterConsoleMessageReceivedCallback(callback);
+ mWebEngine.RegisterConsoleMessageReceivedCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterResponsePolicyDecidedCallback(callback);
+ mWebEngine.RegisterResponsePolicyDecidedCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterNavigationPolicyDecidedCallback(callback);
+ mWebEngine.RegisterNavigationPolicyDecidedCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterNewWindowCreatedCallback(callback);
+ mWebEngine.RegisterNewWindowCreatedCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterCertificateConfirmedCallback(callback);
+ mWebEngine.RegisterCertificateConfirmedCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterSslCertificateChangedCallback(callback);
+ mWebEngine.RegisterSslCertificateChangedCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterHttpAuthHandlerCallback(callback);
+ mWebEngine.RegisterHttpAuthHandlerCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterContextMenuShownCallback(callback);
+ mWebEngine.RegisterContextMenuShownCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.RegisterContextMenuHiddenCallback(callback);
+ mWebEngine.RegisterContextMenuHiddenCallback(std::move(callback));
}
}
{
if(mWebEngine)
{
- mWebEngine.GetPlainTextAsynchronously(callback);
+ mWebEngine.GetPlainTextAsynchronously(std::move(callback));
}
}
if(mVisual)
{
- DevelControl::RegisterVisual(*this, Toolkit::WebView::Property::URL, mVisual);
+ DevelControl::RegisterVisual(*this, Toolkit::WebView::Property::URL, mVisual, DepthIndex::CONTENT);
EnableBlendMode(!mVideoHoleEnabled);
}
}
{
if(type == Dali::DevelActor::VisibilityChange::Type::SELF)
{
- SetVisibility(isVisible);
+ if(isVisible)
+ {
+ mWebViewVisibleState |= WebViewVisibleStateFlag::SELF_SHOW;
+ }
+ else
+ {
+ mWebViewVisibleState &= ~WebViewVisibleStateFlag::SELF_SHOW;
+ }
}
+ else if(type == Dali::DevelActor::VisibilityChange::Type::PARENT)
+ {
+ if(isVisible)
+ {
+ mWebViewVisibleState |= WebViewVisibleStateFlag::PARENT_SHOW;
+ // TODO : We should consider double-hide called from parent
+ }
+ else
+ {
+ mWebViewVisibleState &= ~WebViewVisibleStateFlag::PARENT_SHOW;
+ }
+ }
+ ApplyVisibilityCheck();
+}
+
+void WebView::OnWindowVisibilityChanged(Window window, bool visible)
+{
+ if(visible)
+ {
+ mWebViewVisibleState |= WebViewVisibleStateFlag::WINDOW_SHOW;
+ }
+ else
+ {
+ mWebViewVisibleState &= ~WebViewVisibleStateFlag::WINDOW_SHOW;
+ }
+ ApplyVisibilityCheck();
}
void WebView::OnScreenshotCaptured(Dali::PixelData pixel)
void WebView::OnSceneConnection(int depth)
{
+ mWebViewVisibleState |= WebViewVisibleStateFlag::SCENE_ON;
+ mWebViewVisibleState |= WebViewVisibleStateFlag::PARENT_SHOW;
+ // TODO : We should consider already hided parent
+ Window window = DevelWindow::Get(Self());
+ if(window)
+ {
+ // Hold the weak handle of the placement window.
+ mPlacementWindow = window;
+ if(window.IsVisible())
+ {
+ mWebViewVisibleState |= WebViewVisibleStateFlag::WINDOW_SHOW;
+ }
+ else
+ {
+ mWebViewVisibleState &= ~WebViewVisibleStateFlag::WINDOW_SHOW;
+ }
+ DevelWindow::VisibilityChangedSignal(window).Connect(this, &WebView::OnWindowVisibilityChanged);
+ }
+ ApplyVisibilityCheck();
Control::OnSceneConnection(depth);
EnableBlendMode(!mVideoHoleEnabled);
}
+void WebView::OnSceneDisconnection()
+{
+ mWebViewVisibleState &= ~WebViewVisibleStateFlag::SCENE_ON;
+ mWebViewVisibleState &= ~WebViewVisibleStateFlag::WINDOW_SHOW;
+ mWebViewVisibleState &= ~WebViewVisibleStateFlag::PARENT_SHOW;
+ Window window = mPlacementWindow.GetHandle();
+ if(window)
+ {
+ DevelWindow::VisibilityChangedSignal(window).Disconnect(this, &WebView::OnWindowVisibilityChanged);
+ mPlacementWindow.Reset();
+ }
+ ApplyVisibilityCheck();
+ Control::OnSceneDisconnection();
+}
+
bool WebView::OnTouchEvent(Actor actor, const Dali::TouchEvent& touch)
{
bool result = false;
return mWebEngine ? mWebEngine.SetVisibility(visible) : false;
}
+void WebView::ApplyVisibilityCheck()
+{
+ SetVisibility(mWebViewVisibleState == WebViewVisibleStateFlag::VISIBLE);
+}
+
WebView::WebViewAccessible::WebViewAccessible(Dali::Actor self, Dali::WebEngine& webEngine)
: ControlAccessible(self),
mRemoteChild{},