Marius, Here's what I tried, based on your sample code:
class MyList { val json = JsObj(("tabs", JsArray( JsObj(("class" -> "posts selected")), JsObj(("class" -> "comments")), JsObj(("class" -> "category")), JsObj(("class" ->"famous")), JsObj(("class" -> "random")) ))) def renderButton(xhtml: Group):NodeSeq = { bind("ex", xhtml, "button" -> ajaxButton("Press me", () => { val matches = json.toList.filter(e => e.indexOf("tabs") > -1) JsCrVar("items", json) & JsCrVar("func", Jx(<ul class="tabMenu"> {JxMap(JsVar("it.tabs"), Jx(<li> {JsVar("it", "class")}</li>)) } </ul>).toJs) & (ElemById("items_list") ~> JsFunc("appendChild", Call("func", JsVar("items")))) }) ) } } And here's the html: <lift:surround with="default" at="content"> <div> <div> <lift:MyList.renderButton> <ex:button/> </lift:MyList.renderButton> </div> <div id="items_list"></div> </div> </lift:surround> The button is emitted but the "items" variable is not. In any case, the code above does not do anything. Have I got it all wrong? Glenn Silverman On Apr 16, 9:26 am, "marius d." <marius.dan...@gmail.com> wrote: > Glenn, > > It looks like there was a typo in the book: > > bind("ex", xhtml, > "button" -> SHtml.ajaxButton(Text(Press me), ajaxFunc _) // missing > underscore for partial function application > > If you want to use Jx when say pressing a button ... is it Ajax > something that you're looking for? .. such as: > > 1. Press the button > 2. Return the function generated by Jx and call it by providing a JSON > structure > > Assume you jave a JsObj containing the JSON structure you want. > > var json = JsObj(..) containing the structure: > > // { > // tabs: [ > // {class: posts selected}, > // {class: comments}, > // {class: category}, > // {class: famous}, > // {class: random} > // ] > // } > > bind("text", html, > "show" -> ajaxButton("Press me", () => { > val matches = names.filter(e => e.indexOf(value) > -1) > > JsCrVar("items", json) & > JsCrVar("func", Jx(<ul>{ > JxMap(JsVar("it.tabs"), Jx(<li> > {JsVar("it", "class")}</li>)) > } > </ul>).toJs) & > (ElemById("items_list") ~> JsFunc("appendChild", Call > ("func", JsVar("items")))) > }) > ) > > where items_list is the ID of a div element. > > Would that work for you ? > > Br's, > Marius > > On Apr 16, 6:49 pm, TylerWeir <tyler.w...@gmail.com> wrote: > > > There is an odd issue with quotes getting stripped from the book > > during Lyx -> pdf. > > > This looks to be a case of that. > > > On Apr 16, 11:32 am, glenn <gl...@exmbly.com> wrote: > > > > Marius, > > > > You asked about the Java version I'm using and why I couldn't run the > > > Liftbook > > > example as-is. > > > > My development environment is Eclipse with the scala plugin running > > > Java 1.6. > > > I assume I'm always compiling with the latest scala/lift libraries, as > > > I use maven to > > > package and run. > > > > I get the following compiler error: > > > > "overloaded method value ajaxButton with alternatives (String,() => > > > net.liftweb.http.js.JsCmd,(String, String)*)scala.xml.Elem <and> > > > (scala.xml.NodeSeq,() => net.liftweb.http.js.JsCmd,(String, String)*) > > > scala.xml.Elem cannot be applied to > > > (scala.xml.Text,net.liftweb.http.js.JsCmd) TabMenu.scala > > > sample/src/ > > > main/scala/com/exmbly/scala/sample/snippet Unknown Scala Problem" > > > > Changing the call to > > > > bind("ex", xhtml, > > > "button" -> SHtml.ajaxButton(Text(Press me), () => ajaxFunc) > > > > does work, however (Press me needs to be quoted. It's not in the > > > book). > > > > Glenn Silverman > > > > On Apr 16, 6:49 am, David Pollak <feeder.of.the.be...@gmail.com> > > > wrote: > > > > > On Wed, Apr 15, 2009 at 3:19 PM, glenn <gl...@exmbly.com> wrote: > > > > > > Actually, the json example code in the Liftbook works, as long > > > > > as you change it to read: > > > > > > bind("ex", xhtml, > > > > > "button" -> SHtml.ajaxButton(Text(Press me), () => ajaxFunc) > > > > > > But this example uses a simple function, alert, and emits it using > > > > > JsRaw. > > > > > > I would like to see a similar example, but using Jx to emit a > > > > > javascript function and have it called. > > > > > Jx is for generating functions that generate XML on the client side. > > > > It's > > > > for building rich client-side applications. > > > > > In the button example, the code being called is on the server side, so > > > > the > > > > client-side code is less relevant. > > > > > If you could talk about what you're trying to build, it might be easier > > > > to > > > > discuss things in concrete terms rather than in abstract terms. > > > > > Thanks, > > > > > David > > > > > > Glenn Silverman > > > > > > On Apr 15, 2:58 pm, glenn <gl...@exmbly.com> wrote: > > > > > > Marius, > > > > > > > I appreciate the reply. Not sure if it helps, though. What's with > > > > > > (JsVar("items") and why did you use that? > > > > > > > The Liftbook is very cryptic on the use of Jx classes. It just says, > > > > > > > " If we send this generated JavaScript function to client and > > > > > > calling > > > > > > it by pass the list variable > > > > > > above It will create the following document fragment:..." > > > > > > > Nothing in the book about how to actually do this. > > > > > > > I tried the json example in the book (sec 8.4) and all I got emitted > > > > > > on the client was: > > > > > > <button onclick="lift_ajaxHandler('F560600551708Y4K=true', null, > > > > > > null); return false;">Press me</button> > > > > > > > That doesn't do any good. Generated variable names in emitted > > > > > > javascript aren't much good for referencing in scala classes. > > > > > > > The book is wrong by the way. This won't compile. > > > > > > > bind("ex", xhtml, > > > > > > "button" -> SHtml.ajaxButton(Text(Press me), ajaxFunc) > > > > > > > You need to do something like this: > > > > > > > bind("ex", xhtml, > > > > > > "button" -> SHtml.ajaxButton(Text(Press me), () => ajaxFunc) > > > > > > > Maybe that's why I'm getting 'F560600551708Y4K=true' emitted. > > > > > > > I'm beginning to think nobody has actually written code using the Jx > > > > > > classes > > > > > > that works. > > > > > > > Glenn Silverman > > > > > > > On Apr 15, 12:30 pm, "marius d." <marius.dan...@gmail.com> wrote: > > > > > > > > How about > > > > > > > > 1. Use a decalred variable > > > > > > > > JsCrVar("func", Jx(<ul>{ > > > > > > > JxMap(JsVar("it"), Jx(<li><a > > > > > > > href="">{JsVar("it")}</a></li>)) > > > > > > > } > > > > > > > </ul>).toJs) & Call("func", > > > > > > > JsVar > > > > > > > ("items")) > > > > > > > > 2. > > > > > > > > Jx(<ul>{ > > > > > > > JxMap(JsVar("it"), Jx(<li><a href="">{JsVar("it")}</a></li>)) > > > > > > > }</ul>).toJs asInstanceOf[AnonFunc].applied(JsVar("items")) > > > > > > > > ... that should just call the anonymous function constructed by Jx > > > > > > > > Note that I haven't actaully tested the code but is should work > > > > > > > unless > > > > > > > I'm missing some parentheses etc. > > > > > > > > Also Jx is discussed in the LiftBook > > > > > > > > Br's, > > > > > > > Marius > > > > > > > > On Apr 15, 9:25 pm, glenn <gl...@exmbly.com> wrote: > > > > > > > > > I'm a novice at this, and I've seen discussions of using Jx > > > > > > > > classes > > > > > to > > > > > > > > output HTML on the client, but how exactly is this done? Are > > > > > > > > there > > > > > > > > any complete examples of sending JavaScript functions produced > > > > > > > > by the > > > > > > > > Jx classes to the client and running them? > > > > > > > > > Suppose, for example, I have a json object: > > > > > > > > > var list = { > > > > > > > > tabs: [ > > > > > > > > {class: posts selected}, > > > > > > > > {class: comments}, > > > > > > > > {class: category}, > > > > > > > > {class: famous}, > > > > > > > > {class: random} > > > > > > > > ] > > > > > > > > } > > > > > > > > > and a function defined so: > > > > > > > > > def renderTabs = Jx(<li class='{JsVar("it", "class")}'></li>) > > > > > > > > > I then want to create tabs on the client with > > > > > > > > > Jx(<ul class="tabMenu">{JxMap(JsVar("it.tabs"), > > > > > > > > renderTabs)}</ul>) > > > > > > > > > How, exactly is this to be done? Obviously, this won't work - > > > > > > > > the > > > > > > > > JavaScript function isn't generated: > > > > > > > > > def head(xhtml:NodeSeq): NodeSeq = { > > > > > > > > > val renderTabs = Jx(<li class='{JsVar("it", > > > > > > > > "class")}'></li>) > > > > > > > > > <head> > > > > > > > > <script type="text/javascript"> > > > > > > > > Jx(<ul class="tabMenu">{JxMap(JsVar("it.tabs"), > > > > > > > > renderTabs)}</ul>) > > > > > > > > > </script> > > > > > > > > </head> > > > > > > > > } > > > > > > > > > I see the value in the Jx classes, if only I knew how to use > > > > > > > > them. > > > > > > > > Any help would be appreciated > > > > > > > > > Glenn Silverman > > > > > -- > > > > Lift, the simply functional web frameworkhttp://liftweb.net > > > > Beginning Scalahttp://www.apress.com/book/view/1430219890 > > > > Follow me:http://twitter.com/dpp > > > > Git some:http://github.com/dpp --~--~---------~--~----~------------~-------~--~----~ You received this message because you are subscribed to the Google Groups "Lift" group. To post to this group, send email to liftweb@googlegroups.com To unsubscribe from this group, send email to liftweb+unsubscr...@googlegroups.com For more options, visit this group at http://groups.google.com/group/liftweb?hl=en -~----------~----~----~----~------~----~------~--~---