Bug 134674

Summary: [EFL][WK2] Add a "focus,notfound" signal.
Product: WebKit Reporter: Sanghyup Lee <sh53.lee>
Component: WebKit EFLAssignee: Nobody <webkit-unassigned>
Status: RESOLVED FIXED    
Severity: Normal CC: bunhere, cdumez, commit-queue, gyuyoung.kim, hh.kaka, lucas.de.marchi, ryuan.choi, sergio
Priority: P2    
Version: 528+ (Nightly build)   
Hardware: Unspecified   
OS: Unspecified   
Attachments:
Description Flags
Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
Patch
none
Patch for landing
none
Patch for landing none

Sanghyup Lee
Reported 2014-07-06 21:44:07 PDT
Add a "focus,control,handover" signal to report that user can take the focus from the ewk_view.
Attachments
Patch (4.86 KB, patch)
2014-07-06 21:52 PDT, Sanghyup Lee
no flags
Patch (9.45 KB, patch)
2014-07-07 22:43 PDT, Sanghyup Lee
no flags
Patch (11.46 KB, patch)
2014-07-16 02:48 PDT, Sanghyup Lee
no flags
Patch (11.41 KB, patch)
2014-07-16 03:04 PDT, Sanghyup Lee
no flags
Patch (12.17 KB, patch)
2014-07-16 21:04 PDT, Sanghyup Lee
no flags
Patch (11.56 KB, patch)
2014-07-16 23:03 PDT, Sanghyup Lee
no flags
Patch (11.55 KB, patch)
2014-07-16 23:12 PDT, Sanghyup Lee
no flags
Patch (11.43 KB, patch)
2014-07-16 23:36 PDT, Sanghyup Lee
no flags
Patch for landing (11.45 KB, patch)
2014-07-16 23:47 PDT, Sanghyup Lee
no flags
Patch for landing (11.45 KB, patch)
2014-07-17 03:15 PDT, Sanghyup Lee
no flags
Sanghyup Lee
Comment 1 2014-07-06 21:52:08 PDT
Ryuan Choi
Comment 2 2014-07-06 21:56:56 PDT
Comment on attachment 234477 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=234477&action=review > Source/WebKit2/ChangeLog:9 > + Add a "focus,control,handover" signal to handover its focus control because there are no elements > + of webview to focus on the given direction. Can we test this? > Source/WebKit2/UIProcess/efl/PageUIClientEfl.cpp:103 > + Ewk_Focus_Direction direction = static_cast<Ewk_Focus_Direction>(wkDirection); Nowadays, we didn't just cast WK enum to ewk enum. Please use switch or if statement. > Source/WebKit2/UIProcess/efl/PageUIClientEfl.cpp:104 > + toPageUIClientEfl(clientInfo)->m_view->smartCallback<FocusControlHandover>().call(&direction); Why & ? You just have to pass direction.
Gyuyoung Kim
Comment 3 2014-07-06 22:02:26 PDT
Comment on attachment 234477 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=234477&action=review > Source/WebKit2/ChangeLog:11 > + Remove partial implementation of PageUIClientEfl::takeFocus cause focused evas object has lost "Remove partial implementation of PageUIClientEfl::takeFocus cause focused evas object has lost the focus when the other evas object take the focus." I don't understand this sentence well ?
Sanghyup Lee
Comment 4 2014-07-07 22:43:37 PDT
WebKit Commit Bot
Comment 5 2014-07-07 22:45:27 PDT
Attachment 234546 [details] did not pass style-queue: ERROR: Source/WebKit2/UIProcess/API/efl/EwkViewCallbacks.h:151: Should be indented on a separate line, with the colon or comma first on that line. [whitespace/indent] [4] Total errors found: 1 in 7 files If any of these errors are false positives, please file a bug against check-webkit-style.
Sanghyup Lee
Comment 6 2014-07-16 02:48:59 PDT
Gyuyoung Kim
Comment 7 2014-07-16 02:59:13 PDT
Comment on attachment 234987 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=234987&action=review > Source/WebKit2/UIProcess/API/efl/tests/test_ewk2_view.cpp:250 > +/* Why comment out below test ?
Sanghyup Lee
Comment 8 2014-07-16 03:02:04 PDT
(In reply to comment #7) > (From update of attachment 234987 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=234987&action=review > > > Source/WebKit2/UIProcess/API/efl/tests/test_ewk2_view.cpp:250 > > +/* > > Why comment out below test ? Opps, It's my mistake. I'll fix it.
Sanghyup Lee
Comment 9 2014-07-16 03:04:04 PDT
Gyuyoung Kim
Comment 10 2014-07-16 03:17:52 PDT
Comment on attachment 234990 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=234990&action=review > Source/WebKit2/UIProcess/API/efl/ewk_view.h:42 > + * - "focus,control,handover", Ewk_Focus_Direction*: reports that user can take the focus from the ewk_view because This signal is to notify if focus direction is changed. EWK_FOCUS_DIRECTION_FORWARD or EWK_FOCUS_DIRECTION_BACKWARD. This signal name doesn't contain meaning for user. "focus,direction,changed" looks better. Besides your description regarding "handover focus control bla bla..." is redundant. We only need to explain what does this signal report.
Sanghyup Lee
Comment 11 2014-07-16 17:29:57 PDT
(In reply to comment #10) > (From update of attachment 234990 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=234990&action=review > > > Source/WebKit2/UIProcess/API/efl/ewk_view.h:42 > > + * - "focus,control,handover", Ewk_Focus_Direction*: reports that user can take the focus from the ewk_view because > > This signal is to notify if focus direction is changed. EWK_FOCUS_DIRECTION_FORWARD or EWK_FOCUS_DIRECTION_BACKWARD. This signal name doesn't contain meaning for user. "focus,direction,changed" looks better. Besides your description regarding "handover focus control bla bla..." is redundant. We only need to explain what does this signal report. IMHO, This signal is to notify that there is no focusable element when we press the tab or tab + shift keys regardless of focus direction. Purpose of this signal is to notify that application can handover focus control. Therefore I think this signal name is not bad but you still prefer to "focus,direction,changed", I'll fix it.
Gyuyoung Kim
Comment 12 2014-07-16 17:44:11 PDT
Comment on attachment 234990 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=234990&action=review >>> Source/WebKit2/UIProcess/API/efl/ewk_view.h:42 >>> + * - "focus,control,handover", Ewk_Focus_Direction*: reports that user can take the focus from the ewk_view because >> >> This signal is to notify if focus direction is changed. EWK_FOCUS_DIRECTION_FORWARD or EWK_FOCUS_DIRECTION_BACKWARD. This signal name doesn't contain meaning for user. "focus,direction,changed" looks better. Besides your description regarding "handover focus control bla bla..." is redundant. We only need to explain what does this signal report. > > IMHO, This signal is to notify that there is no focusable element when we press the tab or tab + shift keys regardless of focus direction. > Purpose of this signal is to notify that application can handover focus control. > Therefore I think this signal name is not bad but you still prefer to "focus,direction,changed", I'll fix it. Doesn't Application get focus direction eventually ? Anyway, I think we should use a signal name from the signal occurrence of view. Look at existing signals "title,changed", "url,changed", "webprocess,crashed", If this signal is for notifying there isn't any focusable element, it looks "focus,notfound" can be one of candidates.
Ryuan Choi
Comment 13 2014-07-16 18:16:08 PDT
(In reply to comment #12) > (From update of attachment 234990 [details]) > View in context: https://bugs.webkit.org/attachment.cgi?id=234990&action=review > > >>> Source/WebKit2/UIProcess/API/efl/ewk_view.h:42 > >>> + * - "focus,control,handover", Ewk_Focus_Direction*: reports that user can take the focus from the ewk_view because > >> > >> This signal is to notify if focus direction is changed. EWK_FOCUS_DIRECTION_FORWARD or EWK_FOCUS_DIRECTION_BACKWARD. This signal name doesn't contain meaning for user. "focus,direction,changed" looks better. Besides your description regarding "handover focus control bla bla..." is redundant. We only need to explain what does this signal report. > > > > IMHO, This signal is to notify that there is no focusable element when we press the tab or tab + shift keys regardless of focus direction. > > Purpose of this signal is to notify that application can handover focus control. > > Therefore I think this signal name is not bad but you still prefer to "focus,direction,changed", I'll fix it. > > Doesn't Application get focus direction eventually ? Anyway, I think we should use a signal name from the signal occurrence of view. > > Look at existing signals > > "title,changed", > "url,changed", > "webprocess,crashed", > > If this signal is for notifying there isn't any focusable element, it looks "focus,notfound" can be one of candidates. In my understanding, this signal is fired when user requests to move the focus as specified direction but webview can't move the focus because webvuew already reached the last focusable element of that direction. So, ewk_view does not change any state of itself. It just propagate to the container or application to know that it's your turn to treat user's navigation action. As user scenarios, applications may decide - to move the focus to next widget of ewk_view (normal behavior which I think) - or to move the first focusable element of webview (recursive focus) - or to do nothing Anyway, although I agree with you that this signal name(focus,control,handover) is not usual, I don't have good idea for the better name.
Gyuyoung Kim
Comment 14 2014-07-16 19:04:39 PDT
Comment on attachment 234990 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=234990&action=review >>>>> Source/WebKit2/UIProcess/API/efl/ewk_view.h:42 >>>>> + * - "focus,control,handover", Ewk_Focus_Direction*: reports that user can take the focus from the ewk_view because >>>> >>>> This signal is to notify if focus direction is changed. EWK_FOCUS_DIRECTION_FORWARD or EWK_FOCUS_DIRECTION_BACKWARD. This signal name doesn't contain meaning for user. "focus,direction,changed" looks better. Besides your description regarding "handover focus control bla bla..." is redundant. We only need to explain what does this signal report. >>> >>> IMHO, This signal is to notify that there is no focusable element when we press the tab or tab + shift keys regardless of focus direction. >>> Purpose of this signal is to notify that application can handover focus control. >>> Therefore I think this signal name is not bad but you still prefer to "focus,direction,changed", I'll fix it. >> >> Doesn't Application get focus direction eventually ? Anyway, I think we should use a signal name from the signal occurrence of view. >> >> Look at existing signals >> >> "title,changed", >> "url,changed", >> "webprocess,crashed", >> >> If this signal is for notifying there isn't any focusable element, it looks "focus,notfound" can be one of candidates. > > In my understanding, > this signal is fired when user requests to move the focus as specified direction but webview can't move the focus because webvuew already reached the last focusable element of that direction. > > So, ewk_view does not change any state of itself. It just propagate to the container or application to know that it's your turn to treat user's navigation action. > > As user scenarios, > applications may decide > - to move the focus to next widget of ewk_view (normal behavior which I think) > - or to move the first focusable element of webview (recursive focus) > - or to do nothing > > Anyway, although I agree with you that this signal name(focus,control,handover) is not usual, I don't have good idea for the better name. Right, ryuan. it would be nicer if we add your suggestion to signal description.
Sanghyup Lee
Comment 15 2014-07-16 21:04:46 PDT
Gyuyoung Kim
Comment 16 2014-07-16 21:22:58 PDT
(In reply to comment #15) > Created an attachment (id=235050) [details] > Patch > Anyway, although I agree with you that this signal name(focus,control,handover) is not usual, I don't have good idea for the better name. Sanghyup, this patch is still using "focus,control,handover"...
Ryuan Choi
Comment 17 2014-07-16 21:26:40 PDT
Comment on attachment 235050 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=235050&action=review > Source/WebKit2/UIProcess/API/efl/tests/test_ewk2_view.cpp:1216 > + "<body><input type=\"text\"></body>"; How about using "autofocus" attribute to simplify test test case? As the nit, ' looks easier to read that \" > Source/WebKit2/UIProcess/API/efl/tests/test_ewk2_view.cpp:1223 > + Ewk_Focus_Direction direction; direction = EWK_FOCUS_DIRECTION_FORWARD; ?
Sanghyup Lee
Comment 18 2014-07-16 23:03:15 PDT
Sanghyup Lee
Comment 19 2014-07-16 23:12:20 PDT
Gyuyoung Kim
Comment 20 2014-07-16 23:18:28 PDT
Comment on attachment 235051 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=235051&action=review > Source/WebKit2/ChangeLog:8 > + Add a "focus,control,handover" signal to handover focus control to application focus,control,handover -> focus,notfound ? > Source/WebKit2/ChangeLog:11 > + Application can dicide to move the focus to next widget of ewk_view or something else dicide -> decide > Source/WebKit2/UIProcess/API/efl/EwkViewCallbacks.h:56 > + FocusNotfound, FocusNotfound -> FocusNotFound > Source/WebKit2/UIProcess/API/efl/ewk_view.h:42 > + * - "focus,notfound", Ewk_Focus_Direction*: reports that there is no elements of webview to focus on the given > reports that there is no elements of webview to focus on the given direction because webview already reached the last focusable element. Application can dicide to move the focus to next widget of ewk_view or something else by using this signal. "reports that there was no element to be focused on the given direction. The user can handle focus behavior using the signal."
Gyuyoung Kim
Comment 21 2014-07-16 23:20:38 PDT
(In reply to comment #20) > "reports that there was no element to be focused on the given direction. The user can handle focus behavior using the signal." > "reports that there was no element to be focused on the given direction. The user can handle next focus behavior using the signal."
Sanghyup Lee
Comment 22 2014-07-16 23:36:33 PDT
Gyuyoung Kim
Comment 23 2014-07-16 23:39:08 PDT
Comment on attachment 235055 [details] Patch View in context: https://bugs.webkit.org/attachment.cgi?id=235055&action=review > Source/WebKit2/UIProcess/API/efl/tests/UnitTestUtils/EWK2UnitTestBase.cpp:328 > + Evas* evas = evas_object_evas_get(m_webView); It would be good if you add ASSERT(evas).
Sanghyup Lee
Comment 24 2014-07-16 23:47:59 PDT
Created attachment 235056 [details] Patch for landing
Sanghyup Lee
Comment 25 2014-07-17 02:56:41 PDT
Comment on attachment 235056 [details] Patch for landing Gyuyoung, I'm sorry. Could you please review again?
Gyuyoung Kim
Comment 26 2014-07-17 03:10:33 PDT
(In reply to comment #25) > (From update of attachment 235056 [details]) > Gyuyoung, I'm sorry. Could you please review again? I already set r+ed. In that case, you don't need to request review again if you fill ChangeLog with "Reviewed by Gyuyoung Kim". Then, you can just request cq? committer can land.
Sanghyup Lee
Comment 27 2014-07-17 03:15:14 PDT
Created attachment 235061 [details] Patch for landing
WebKit Commit Bot
Comment 28 2014-07-17 03:56:19 PDT
Comment on attachment 235061 [details] Patch for landing Clearing flags on attachment: 235061 Committed r171182: <http://trac.webkit.org/changeset/171182>
WebKit Commit Bot
Comment 29 2014-07-17 03:56:26 PDT
All reviewed patches have been landed. Closing bug.
Note You need to log in before you can comment on or make changes to this bug.