Actually, this might be a good idea, given all browsers support
script.readState consistently, which I need to confirm first. Apart
from that, I don't see any problem with it so far.

-Matej

On 10/19/07, Alexei Sokolov <[EMAIL PROTECTED]> wrote:
> Actually,
>
> The following code seems to be working in ie and firefox for me, but it was
> a very simple test.
>
> Alex
>
>     processScript: function(steps, node) {
>         steps.push(function(notify) {
>             if (Wicket.DOM.containsElement(node) ||
>                 Wicket.Head.containsElement(node, "src")) {
>                 notify();
>                 return;
>             }
>             var src = node.getAttribute("src");
>             if (src != null && src != "") {
>
>                 var script = Wicket.Head.createElement("script");
>                 script.src = src;
>                 var done = false;
>
>                 // Attach handlers for all browsers
>                 script.onload = script.onreadystatechange = function(){
>                     if ( !done && (!this.readyState ||
>                             this.readyState == "loaded" ||
> this.readyState== "complete") ) {
>                         done = true;
>
>                         var head = document.getElementsByTagName("head");
>
>                         if (head[0]) {
>                             // how about Wicket.Head.removeElement() ???
>                             head[0].removeChild(script);
>                         }
>                         // maybe I need to do something here?
>                         notify();
>                     }
>                 };
>                 Wicket.Head.addElement(script);
>
>
>                 //var onLoad = function() {
>                 //    Wicket.Head.addJavascript(content, null, src);
>                 //    Wicket.Ajax.invokePostCallHandlers();
>                 //    notify();
>                 //}
>
>                 // we need to schedule the request as timeout
>                 // calling xml http request from another request call stack
> doesn't work
>                 //window.setTimeout(function() {
>                 //    var req = new Wicket.Ajax.Request(src, onLoad, false,
> false);
>                 //    req.debugContent = false;
>                 //    if (Wicket.Browser.isKHTML())
>                 //        req.async = false;
>                 //    req.get();
>                 // },1);
>             } else {
>                 var text = Wicket.DOM.serializeNodeChildren(node);
>                 Wicket.Head.addJavascript(text, node.getAttribute("id"));
>                 notify();
>             }
>         });
>     }
>
> On 10/18/07, Igor Vaynberg <[EMAIL PROTECTED]> wrote:
> >
> > matej what do you think about this?
> >
> > -igor
> >
> >
> > On 10/18/07, Alexei Sokolov <[EMAIL PROTECTED]> wrote:
> > > Maybe something similar to this:
> > > http://docs.jquery.com/Ajax/jQuery.getScript. They use <script> tag
> > > injection (see 1.2.1 jquery source code).
> > >
> > > Alex
> > >
> > > On 10/18/07, Igor Vaynberg <[EMAIL PROTECTED]> wrote:
> > > >
> > > > do you have any suggestions on how to fix it?
> > > >
> > > > -igor
> > > >
> > > >
> > > > On 10/18/07, Alexei Sokolov <[EMAIL PROTECTED]> wrote:
> > > > > Hey guys,
> > > > >
> > > > > Very good progress on 1.3 release, congratulations.
> > > > > However, there is an  issue which somebody complained around july
> > 31,
> > > > > 07 that has not been
> > > > > addressed yet.
> > > > >
> > > > > Short description: I cannot reference any external javascript files
> > > > (from
> > > > > yahoo, google, even from subdomain) in markup of a panel if I want
> > that
> > > > > panel to be updated using ajax. All browsers complain.
> > > > >
> > > > > Long Description: I believe the problem lies inside wicket-ajax.js,
> > more
> > > > > precisely in Wicket.Head.Contributor.ProcessScript method. Existing
> > > > > implementation attempts to load the referenced script using ajax,
> > and
> > > > > browsers do not allow that due to security concerns. See any article
> > on
> > > > > cross-domain ajax for the explanation why.
> > > > >
> > > > > Steps to reproduce:
> > > > >
> > > > > 1. create a panel.
> > > > > 2. include something like <wicket:head><script
> > type="text/javascript"
> > > > src="
> > > > > http://blah.blah.com/script.js";></script></wicket:head>
> > > > > 3. attempt to update the panel using ajax
> > > > > 4. each and every browser will complain, but the error will be
> > > > > slightly different. firefox will say "uncaught exception: Permission
> > > > > denied to call method XMLHttpRequest.open"
> > > > >
> > > > >
> > > > > Alex
> > > > >
> > > >
> > >
> >
>

Reply via email to