[ 
https://issues.apache.org/jira/browse/WICKET-6055?page=com.atlassian.jira.plugin.system.issuetabpanels:comment-tabpanel&focusedCommentId=15136215#comment-15136215
 ] 

ASF GitHub Bot commented on WICKET-6055:
----------------------------------------

Github user dashorst commented on a diff in the pull request:

    https://github.com/apache/wicket/pull/151#discussion_r52115636
  
    --- Diff: 
wicket-extensions/src/main/java/org/apache/wicket/extensions/ajax/markup/html/AjaxLazyLoadPanel.java
 ---
    @@ -139,56 +182,176 @@ protected void handleCallbackScript(final 
IHeaderResponse response,
        @Override
        protected void onBeforeRender()
        {
    -           if (state == 0)
    +           if (state == LoadingState.WAITING_FOR_LAZY_COMPONENT)
                {
                        add(getLoadingComponent(LAZY_LOAD_COMPONENT_ID));
    -                   setState((byte)1);
    +                   setState(LoadingState.REPLACING_LAZY_COMPONENT);
                }
                super.onBeforeRender();
        }
     
    +   @Override
    +   public void onEvent(IEvent<?> event)
    +   {
    +           super.onEvent(event);
    +
    +           if (state == LoadingState.REPLACING_LAZY_COMPONENT)
    --- End diff --
    
    No, as `isReadyForReplacement()` is actually there for preventing 
replacement prematurely. Why would you wait until some time in the future to do 
the replacement when you can replace now and the component is ready for 
replacement?


> AjaxLazyLoadPanel should provide non-blocking lazy load
> -------------------------------------------------------
>
>                 Key: WICKET-6055
>                 URL: https://issues.apache.org/jira/browse/WICKET-6055
>             Project: Wicket
>          Issue Type: Improvement
>          Components: wicket-extensions
>    Affects Versions: 7.1.0
>            Reporter: Martijn Dashorst
>            Assignee: Martijn Dashorst
>
> When having multiple AjaxLazyLoadPanels on your page, they all block their 
> Wicket request thread until the content is ready to load. This can be 
> problematic when you try to wait for some background job to finish and want 
> to poll for that job to be ready, and only then update the contents.
> The improvement would be to add a method that gives the developer the option 
> to not update just yet (isReadyForReplacement) and when it returns true, 
> start the replacement. By default this would return true, implementing the 
> current behavior of the AjaxLazyLoadPanel.
> Furthermore to improve the responsiveness of the ALLP it should add a single 
> timer to the page that can be used by multiple ALLPs to update themselves. 
> The timer would poll each second and the ALLPs would use Wicket's event bus 
> to update themselves. With some reference counting, the timer can remove 
> itself from the page when all ALLPs have updated themselves.
> This enables refreshing the page as well when outside an AJAX context, or 
> having a user be impatient and pressing F5.



--
This message was sent by Atlassian JIRA
(v6.3.4#6332)

Reply via email to