The dummy button 60/94260/1
authorm.kawonczyk <m.kawonczyk@samsung.com>
Mon, 3 Oct 2016 06:53:08 +0000 (08:53 +0200)
committerHyeKyoung Hwang <cookie@samsung.com>
Fri, 28 Oct 2016 02:12:45 +0000 (11:12 +0900)
[Issue]        http://suprem.sec.samsung.net/jira/browse/TWF-2222
[Problem]      The dummy button is needed by webview for focus
               managment.
[Solution]     Add #ifdefed the dummy button feature.
[Verify]       Open any webpage, dlogutil browser. Check if the
               dummy button is properly focused/unfocused and if
               webview focus is ok.

Change-Id: I66f9bcc00e8eaf0b4c708ca1fae3c367a9ea06ff

CMakeLists.txt
cmake/EDCCompile.cmake
core/AbstractWebEngine/AbstractWebEngine.h
services/SimpleUI/SimpleUI.cpp
services/WebEngineService/WebEngineService.cpp
services/WebEngineService/WebEngineService.h
services/WebEngineService/WebView.cpp
services/WebEngineService/WebView.h
services/WebPageUI/WebPageUI.cpp
services/WebPageUI/WebPageUI.h
services/WebPageUI/edc/WebPageUI_mob.edc

index a56ceb137a3c0cc47efa30a07d1cb6ec18051324..bc70127653617c1ec65965a1e58d825ec71df2a0 100755 (executable)
@@ -116,6 +116,7 @@ if(TIZEN_BUILD)
 
     if (${PROFILE} MATCHES "mobile")
         ADD_DEFINITIONS(-DPROFILE_MOBILE=1)
+        ADD_DEFINITIONS(-DDUMMY_BUTTON=1)
     endif (${PROFILE} MATCHES "mobile")
 
 endif(TIZEN_BUILD)
index 5dfb6e8689e030f8cb4477168fdc2b73de9637ab..6f9a340956b209388c851b3bd47a9b8e605ecb43 100644 (file)
@@ -34,6 +34,7 @@ IF(EDJE_CC_EXECUTABLE)
                                 ARGS -id ${CMAKE_CURRENT_SOURCE_DIR}/${IMAGES_URL}/
                                 -DBROWSER_RESOLUTION_${resolution}=1
                                 -DPROFILE_MOBILE=${IF_PROFILE_MOBILE}
+                                -DDUMMY_BUTTON=${IF_DUMMY_BUTTON}
                                 ${Edc_Input} ${tmp_output}
                                 MAIN_DEPENDENCY ${Edc_Input}
                                 DEPENDS ${EDJE_TARGET_depends}
index e33c85b75d5c86e5002cefe6d27d583cd82e3d53..f5b86dc5663bc8ecf612fbcf4cbe2a86cbda2cd9 100644 (file)
@@ -55,12 +55,13 @@ public:
      */
     virtual T * getLayout() = 0;
 
+#if !DUMMY_BUTTON
     /**
      * Remember that there must be at least 1 tab created to return layout
      * @return pointer to Evas_Object widget connected with a current WebView.
      */
     virtual Evas_Object* getWidget() = 0;
-
+#endif
     /**
      * Initialize WebEngine.
      * @param guiParent GUI parent object (now should pass Evas_Object)
index 4e457d53254498c00621304de3c26860282f2090..2a2bb64883a1b2c8dd12d3b8a23685b06f7a9001 100644 (file)
@@ -137,6 +137,9 @@ void SimpleUI::suspend()
 void SimpleUI::resume()
 {
     m_webEngine->preinitializeWebViewCache();
+#if DUMMY_BUTTON
+    m_webPageUI->createDummyButton();
+#endif
     m_webEngine->resume();
 #if PROFILE_MOBILE
     if (m_findOnPageUI && m_findOnPageUI->isVisible())
index 9eeb1b6690a3de9c0a36ca2ca9295d9b1bbe3bca..3b0a0043de51c63e946962366d514eb28eb29f55 100755 (executable)
@@ -83,6 +83,7 @@ Evas_Object * WebEngineService::getLayout()
     return m_currentWebView->getLayout();
 }
 
+#if !DUMMY_BUTTON
 Evas_Object * WebEngineService::getWidget()
 {
     BROWSER_LOGD("[%s:%d] ", __PRETTY_FUNCTION__, __LINE__);
@@ -93,7 +94,7 @@ Evas_Object * WebEngineService::getWidget()
     }
     return m_currentWebView->getWidget();
 }
-
+#endif
 void WebEngineService::init(void * guiParent)
 {
     BROWSER_LOGD("[%s:%d] ", __PRETTY_FUNCTION__, __LINE__);
index 925cb846a96231d36829959ac0a3da2e27e2102a..2d21c5b7a9e291b42070b5026038c078ae1b3e2b 100644 (file)
@@ -50,7 +50,9 @@ public:
     virtual std::string getName();
 
     Evas_Object * getLayout();
+#if !DUMMY_BUTTON
     Evas_Object * getWidget();
+#endif
     void init(void * guiParent);
     void preinitializeWebViewCache();
 
index 5e07c4db6bbb8d05dadbfcbd01cdb7fe40881157..be41f620f46a9fa4a7db5dbe49345107933f3a4e 100755 (executable)
@@ -648,11 +648,12 @@ Evas_Object * WebView::getLayout()
     return m_ewkView;
 }
 
+#if !DUMMY_BUTTON
 Evas_Object * WebView::getWidget()
 {
     return ewk_view_widget_get(m_ewkView);
 }
-
+#endif
 void WebView::setURI(const std::string & uri)
 {
     BROWSER_LOGD("[%s:%d] uri=%s", __PRETTY_FUNCTION__, __LINE__, uri.c_str());
index 97e0750610f9ab5add8325835fc476600ae1e7ae..85ed5922f20da21b502542d71898537a1e3603b2 100644 (file)
@@ -109,8 +109,9 @@ public:
     std::map<std::string, std::vector<std::string> > parse_uri(const char *uriToParse);
 
     Evas_Object * getLayout();
+#if !DUMMY_BUTTON
     Evas_Object * getWidget();
-
+#endif
     void confirmationResult(WebConfirmationPtr);
 
     /**
index 953dc6f37aeef27b7432eec9cc6c84d456ebcd1b..c2b4f98242d9ed9b5a2d703b813775ad02d2c7ac 100755 (executable)
@@ -37,6 +37,9 @@ EXPORT_SERVICE(WebPageUI, "org.tizen.browser.webpageui")
 WebPageUI::WebPageUI()
     : m_parent(nullptr)
     , m_mainLayout(nullptr)
+#if DUMMY_BUTTON
+    , m_dummy_button(nullptr)
+#endif
     , m_errorLayout(nullptr)
     , m_privateLayout(nullptr)
     , m_bookmarkManagerButton(nullptr)
@@ -59,6 +62,10 @@ WebPageUI::WebPageUI()
 WebPageUI::~WebPageUI()
 {
     BROWSER_LOGD("[%s:%d] ", __PRETTY_FUNCTION__, __LINE__);
+#if DUMMY_BUTTON
+    evas_object_smart_callback_del(m_dummy_button, "focused", _dummy_button_focused);
+    evas_object_smart_callback_del(m_dummy_button, "unfocused", _dummy_button_unfocused);
+#endif
 }
 
 void WebPageUI::init(Evas_Object* parent)
@@ -207,8 +214,10 @@ void WebPageUI::setMainContent(Evas_Object* content)
 #if PROFILE_MOBILE && GESTURE
     elm_gesture_layer_attach(m_gestureLayer, content);
 #endif
-#if PROFILE_MOBILE
+#if PROFILE_MOBILE && !DUMMY_BUTTON
     evas_object_smart_callback_add(content, "mouse,down", _content_clicked, this);
+#endif
+#if PROFILE_MOBILE
     updateManualRotation();
 #endif
     evas_object_show(content);
@@ -484,6 +493,45 @@ void WebPageUI::createLayout()
 #endif
 }
 
+#if DUMMY_BUTTON
+void WebPageUI::createDummyButton()
+{
+    BROWSER_LOGD("[%s:%d] ", __PRETTY_FUNCTION__, __LINE__);
+    if (!m_dummy_button) {
+        M_ASSERT(m_mainLayout);
+        m_dummy_button = elm_button_add(m_mainLayout);
+        elm_object_style_set(m_dummy_button, "invisible_button");
+        evas_object_size_hint_align_set(m_dummy_button, EVAS_HINT_FILL, EVAS_HINT_FILL);
+        evas_object_size_hint_weight_set(m_dummy_button, EVAS_HINT_EXPAND, EVAS_HINT_EXPAND);
+        elm_object_focus_allow_set(m_dummy_button, EINA_TRUE);
+        elm_object_focus_set(m_dummy_button, EINA_TRUE);
+        evas_object_show(m_dummy_button);
+        elm_object_part_content_set(m_mainLayout, "web_view_dummy_button", m_dummy_button);
+
+        evas_object_smart_callback_add(m_dummy_button, "focused", _dummy_button_focused, this);
+        evas_object_smart_callback_add(m_dummy_button, "unfocused", _dummy_button_unfocused, this);
+    }
+}
+
+void WebPageUI::_dummy_button_focused(void *data, Evas_Object *, void *)
+{
+    BROWSER_LOGD("[%s:%d] ", __PRETTY_FUNCTION__, __LINE__);
+    if (data != nullptr) {
+        WebPageUI* webPageUI = static_cast<WebPageUI*>(data);
+        webPageUI->focusWebView();
+    }
+}
+
+void WebPageUI::_dummy_button_unfocused(void *data, Evas_Object *, void *)
+{
+    BROWSER_LOGD("[%s:%d] ", __PRETTY_FUNCTION__, __LINE__);
+    if (data != nullptr) {
+        WebPageUI* webPageUI = static_cast<WebPageUI*>(data);
+        webPageUI->unfocusWebView();
+    }
+}
+
+#endif
 void WebPageUI::createErrorLayout()
 {
     BROWSER_LOGD("[%s:%d] ", __PRETTY_FUNCTION__, __LINE__);
index d11e918082ae45bb19ec5768d9f7ab462db3c63e..459879db853230752550c07377a5dc09c4581abc 100644 (file)
@@ -53,6 +53,9 @@ public:
     UrlHistoryPtr getUrlHistoryList();
     virtual void showUI();
     virtual void hideUI();
+#if DUMMY_BUTTON
+    void createDummyButton();
+#endif
 #if PROFILE_MOBILE
     virtual void orientationChanged() override;
     void fullscreenModeSet(bool state);
@@ -121,6 +124,10 @@ private:
     static void faviconClicked(void* data, Evas_Object* obj, const char* emission, const char* source);
     static Eina_Bool _cb_down_pressed_on_urlbar(void *data, Evas_Object *obj, Evas_Object *src, Evas_Callback_Type type, void *event_info);
     static void _bookmark_manager_clicked(void * data, Evas_Object *, void *);
+#if DUMMY_BUTTON
+    static void _dummy_button_focused(void *data, Evas_Object *, void *);
+    static void _dummy_button_unfocused(void *data, Evas_Object *, void *);
+#endif
 #if PROFILE_MOBILE
     static void _more_menu_background_clicked(void* data, Evas_Object*, const char*, const char*);
     static void _content_clicked(void * data, Evas_Object *, void *);
@@ -161,6 +168,9 @@ private:
 
     Evas_Object* m_parent;
     Evas_Object* m_mainLayout;
+#if DUMMY_BUTTON
+    Evas_Object* m_dummy_button;
+#endif
     Evas_Object* m_errorLayout;
     Evas_Object* m_privateLayout;
     Evas_Object* m_bookmarkManagerButton;
index 116caa02c3602ead40149179b167899754d809d5..1e7efa05ad21236df5ed108bb57c3a1f678fd4c0 100644 (file)
@@ -299,6 +299,21 @@ collections { base_scale: 2.6;
                     rel2 { relative: 1.0 1.0; to: "bg"; }
                 }
             }
+#if DUMMY_BUTTON
+            swallow { "web_view_dummy_button"; scale;
+                mouse_events: 1;
+                repeat_events: 1;
+                description { "default";
+                    visible: 1;
+                    align: 0.0 0.0;
+                    fixed: 0 0;
+                    min: 0 0;
+                    max: -1 -1;
+                    rel1 { relative: 0.0 0.0; to: "web_view"; }
+                    rel2 { relative: 1.0 1.0; to: "web_view"; }
+                }
+            }
+#endif
             part { name: "progressbar_bg";
                 type: IMAGE;
                 scale: 1;