You're right, he is talking about something else :) Since you can add a
Behavior to multiple components, maybe Vincent can create a Behavior to do
this. If he does this, then he can share my problem :)

So back to my problem... I need something more than window.onload, I think.
Wicket already has very sophisticated script block handling in wicket-ajax
where the insertion order of script and other dom is preserved in the
evaluation order. It would be great if Behaviors could take advantage of
this, since they are the primary way of inserting script with wicket.
However, i think Behaviors were created pre wicket-ajax and are therefore
somewhat Page rendering centric in their design. window.onload is also page
rendering specific. I'm talking about having Behaviors bridge the ajax and
page rendering worlds through some form of adaptation. This way, if the
Behavior was Page rendered, it could add itself to the window.onload queue,
if ajax rendered, it can put itself in the appropriate place in the xml
envelope and wicket-ajax takes care of the rest. The rest of wicket is
really seamless in its ajax/page rendering support, but this is one place
that isn't.

thx,
jim

On 1/23/07, Igor Vaynberg <[EMAIL PROTECTED]> wrote:

i think he is talking about something a bit different

what you want can be accomplished by using a bit of javascript foo

http://ejohn.org/projects/flexible-javascript-events/

you can use that func to register a bunch of window.onload events that
execute once the html has been rendered. we were discussing about
implementing that as part of wicket to have nice serverside api support
for
it, but havent had the time yet. matej?

-igor


On 1/23/07, James McLaughlin <[EMAIL PROTECTED]> wrote:
>
> I ran into this issue a while back and proposed an IOnLoadContributor
> interface that kind of mirrors all the good work of IHeaderContributor,
> but
> for script that is inserted anywhere below </head>, such as onload, or
> script blocks in the actual body.
> http://www.nabble.com/rfc-OnLoadContributor-tf2609406.html#a7282114
>
> I'm getting around it now by having my Behaviors check the Target type
in
> onRendered, which works great for Ajax requests. For non-ajax, you need
to
> worry if the script block will end up in a place that isn't cool for ie.
>
> On 1/23/07, Vincent Demay <[EMAIL PROTECTED]> wrote:
> >
> > Hi all,
> >
> > When I re-render a Dojo widget via an ajaxRequestTarget, I have to add
> > some javascript to the request depending on which widget(component)
has
> > been added to the target. This javascript should be added in order to
> > re-parse new DojoWidget (from the ajax response) with dojo API. This
> > kind of parsing should only be done on top level Dojo component
because
> > during parsing sub-dojo-components will be automaticaly parsed.
> >
> > Actually what I need to do is  :
> >
> > before sending response
> > 1 - looking for all component added to the target
> > 2 - for all top-level Dojo components :
> >        Adding its id to a map
> > 3 - adding a js such as
> >
> > djConfig.searchIds = ['id1','id2','id3'];dojo.hostenv.makeWidgets().
> >
> > My problem is I can not do a such stuff in a ajaxBehavior.respond
> > because this should be done once by request and i do not have any
access
> > to the component list added to the target. On the other hand I can not
> > extends AjaxRequestTarget because If i do that I can not use AjaxLink
or
> > other Ajax* to re-render a Dojo Component.
> >
> > So I thought to add a listener on AjaxRequestTarget that should be
> > called after respondComponent in respondComponents method such as a
> > IAjaxResponseListener with a onRender(Map/* <String,Component>
> > */markupIdToComponent, AjaxRequestTarget target) method.
> >
> > Have you a better idea and WDYT about listener?
> >
> > thanks a lot
> >
> > --
> > Vincent
> >
>
>


Reply via email to