diff options
author | Adam Chlipala <adam@chlipala.net> | 2011-05-29 12:44:31 -0400 |
---|---|---|
committer | Adam Chlipala <adam@chlipala.net> | 2011-05-29 12:44:31 -0400 |
commit | 72f0b5eb660181f57a2cae08b3bec54ae2b543e7 (patch) | |
tree | 1f5fac0828731fd598a24d7b5361ebc38e203a66 | |
parent | d08b89fd32f79f2b24bb3f018d5db499f0751518 (diff) |
Properly handle form textboxes that have sources
-rw-r--r-- | lib/js/urweb.js | 7 | ||||
-rw-r--r-- | src/monoize.sml | 8 | ||||
-rw-r--r-- | tests/tsource.ur | 28 | ||||
-rw-r--r-- | tests/tsource.urs | 1 |
4 files changed, 38 insertions, 6 deletions
diff --git a/lib/js/urweb.js b/lib/js/urweb.js index 5a6ce21f..a3ab6fde 100644 --- a/lib/js/urweb.js +++ b/lib/js/urweb.js @@ -461,7 +461,8 @@ function dyn(pnode, s) { populate(x); } -function input(x, s, recreate, type) { +function input(x, s, recreate, type, name) { + if (name) x.name = name; if (type) x.type = type; x.dead = false; x.signal = ss(s); @@ -473,9 +474,9 @@ function input(x, s, recreate, type) { return x; } -function inp(s) { +function inp(s, name) { var x = input(document.createElement("input"), s, - function(x) { return function(v) { if (x.value != v) x.value = v; }; }); + function(x) { return function(v) { if (x.value != v) x.value = v; }; }, null, name); x.value = s.data; x.onkeyup = function() { sv(s, x.value) }; diff --git a/src/monoize.sml b/src/monoize.sml index 856cd43e..85b9a39e 100644 --- a/src/monoize.sml +++ b/src/monoize.sml @@ -2737,8 +2737,8 @@ fun monoExp (env, st, fm) (all as (e, loc)) = (L.EFfi ("Basis", "sql_nfunc"), _), _), _), _), _), - _), _), - _) => + _), _), + _) => let val s = (L'.TFfi ("Basis", "string"), loc) fun sc s = (L'.EPrim (Prim.String s), loc) @@ -3258,7 +3258,9 @@ fun monoExp (env, st, fm) (all as (e, loc)) = | SOME (_, src, _) => (strcat [str "<script type=\"text/javascript\">inp(exec(", (L'.EJavaScript (L'.Script, src), loc), - str "))</script>"], + str "), \"", + str name, + str "\")</script>"], fm)) | _ => (Print.prefaces "Targs" (map (fn t => ("T", CorePrint.p_con env t)) targs); raise Fail "No name passed to textbox tag")) diff --git a/tests/tsource.ur b/tests/tsource.ur new file mode 100644 index 00000000..20cb4860 --- /dev/null +++ b/tests/tsource.ur @@ -0,0 +1,28 @@ +fun doSubmit r = + return <xml>Done {[readError r.Amount1 * readError r.Amount2 * 2.0]}</xml> + +fun main () = + amount1S <- source "1"; + amount2S <- source "1"; + return <xml> <body> + <form> + <table> + <tr><td>Amount1:</td><td><textbox{#Amount1} +source={amount1S}/></td></tr> + <tr><td>Amount2:</td><td><textbox{#Amount2} +source={amount2S}/></td></tr> + <tr><td>Total:</td><td><dyn signal={showTotal amount1S +amount2S}/></td></tr> + </table> + <submit value="Buy" action={doSubmit}/> + </form> + </body> +</xml> + +and showTotal amount1S amount2S = + a1 <- signal amount1S; + a2 <- signal amount2S; + return (case ((read a1), (read a2)) of + (None, _) => <xml></xml> + | (_, None) => <xml></xml> + | (Some a, Some b) => <xml>{[a * b * 2.0]}</xml>) diff --git a/tests/tsource.urs b/tests/tsource.urs new file mode 100644 index 00000000..6ac44e0b --- /dev/null +++ b/tests/tsource.urs @@ -0,0 +1 @@ +val main : unit -> transaction page |