diff options
author | Adam Chlipala <adamc@hcoop.net> | 2009-08-06 14:24:40 -0400 |
---|---|---|
committer | Adam Chlipala <adamc@hcoop.net> | 2009-08-06 14:24:40 -0400 |
commit | 372c06af1af7e70223dcc21098b13d7bd8c98bf3 (patch) | |
tree | 8539a9b6f15a96a49a991341b0a0265d02f64e78 | |
parent | db5124e67d20894db9fd6b41c93b0de13dc6892d (diff) |
dlist row add working with Konqueror
-rw-r--r-- | lib/js/urweb.js | 51 | ||||
-rw-r--r-- | src/monoize.sml | 30 |
2 files changed, 53 insertions, 28 deletions
diff --git a/lib/js/urweb.js b/lib/js/urweb.js index 05d32e90..06ff19cf 100644 --- a/lib/js/urweb.js +++ b/lib/js/urweb.js @@ -252,7 +252,7 @@ function runScripts(node) { doExn(v); } if (thisScript.parentNode) - thisScripts.parentNode.removeChild(thisScript); + thisScript.parentNode.removeChild(thisScript); } thisScript = savedScript; @@ -262,23 +262,22 @@ function runScripts(node) { // Dynamic tree entry points -function dyn(s) { - var x = document.createElement("div"); - x.style.display = "inline"; +function dyn(pnode, s) { + var x = document.createElement("script"); x.dead = false; x.signal = s; x.sources = null; x.closures = null; - var first = null; + var child = null; x.recreate = function(v) { for (var ls = x.closures; ls; ls = ls.next) freeClosure(ls.data); - for (var node = first; node && node != x; ) { - if (node.getElementsByTagName) { - var arr = node.getElementsByTagName("div"); + if (child) { + if (child.getElementsByTagName) { + var arr = child.getElementsByTagName("script"); for (var i = 0; i < arr.length; ++i) { var span = arr[i]; span.dead = true; @@ -289,24 +288,36 @@ function dyn(s) { } } - var old = node; - node = node.nextSibling; - if (old.parentNode) - old.parentNode.removeChild(old); + if (child.parentNode) + child.parentNode.removeChild(child); } var cls = {v : null}; - var dummy = document.createElement("table"); - dummy.innerHTML = flatten(cls, v); + var html = flatten(cls, v); x.closures = cls.v; - runScripts(dummy); - for (first = dummy.firstChild; first && first.tagName == "TBODY"; first = first.firstChild); - for (var node = first; node; ) { - var old = node; - node = node.nextSibling; + if (pnode == "table") { + var dummy = document.createElement("body"); + dummy.innerHTML = "<table>" + html + "</table>"; + runScripts(dummy); + var rows = dummy.firstChild.rows; + var nRows = rows.length; + var table = x.parentNode; + + var arr = dummy.getElementsByTagName("tbody"); + if (arr.length > 0) { + var tbody = arr[0], next; + for (var node = tbody.firstChild; node; node = next) { + next = node.nextSibling; + table.appendChild(node); + } + } + } else { + child = document.createElement("span"); + child.innerHTML = html; + runScripts(child); if (x.parentNode) - x.parentNode.insertBefore(old, x); + x.parentNode.insertBefore(child, x); } }; diff --git a/src/monoize.sml b/src/monoize.sml index f0491198..bd666edf 100644 --- a/src/monoize.sml +++ b/src/monoize.sml @@ -2644,14 +2644,28 @@ fun monoExp (env, st, fm) (all as (e, loc)) = end | "dyn" => - (case attrs of - [("Signal", e, _)] => - ((L'.EStrcat - ((L'.EPrim (Prim.String ("<script type=\"text/javascript\">dyn(")), loc), - (L'.EStrcat ((L'.EJavaScript (L'.Script, e), loc), - (L'.EPrim (Prim.String (")</script>")), loc)), loc)), loc), - fm) - | _ => raise Fail "Monoize: Bad dyn attributes") + let + val inTable = case targs of + (L.CRecord (_, ctx), _) :: _ => + List.exists (fn ((L.CName "Table", _), _) => true + | _ => false) ctx + | _ => false + + val tag = if inTable then + "table" + else + "span" + in + case attrs of + [("Signal", e, _)] => + ((L'.EStrcat + ((L'.EPrim (Prim.String ("<script type=\"text/javascript\">dyn(\"" + ^ tag ^ "\", ")), loc), + (L'.EStrcat ((L'.EJavaScript (L'.Script, e), loc), + (L'.EPrim (Prim.String (")</script>")), loc)), loc)), loc), + fm) + | _ => raise Fail "Monoize: Bad dyn attributes" + end | "submit" => normal ("input type=\"submit\"", NONE, NONE) | "button" => normal ("input type=\"submit\"", NONE, NONE) |