Forum OpenACS Development: Re: Looking for guidance is using template_tag to modify "input" tag

Hi Brian,

below is a simple study that shows how to translate certain input tags in .adp pages (the example translates such tags into input tags of type 'text' with class "invisible"). I've tested this with plain NaviServer in an .adp page.

The OpenACS templating system is in some respects more tricky, since it has it own templating system on top of this for processing of the @-variables. It "compiles" such .adp file into low-level NaviServer pages and uses these later for delivery. So, when you add some tag definitions at runtime, there is no code that invalidates the already compiled pages.... that might be an explanation for the strange behavior you observed. .... so the best thing is to restart the server after adding tags.

all the best -g

library script

namespace eval ::template {

    proc tag-input {set} {
        set attrs [ns_set array $set]

        if {[dict exists $attrs type] && [dict get $attrs type] eq "hidden"} {
            dict set attrs class hidden
            dict set attrs type text
        } else {
            dict set attrs class visible
        set output [join [lmap {k v} $attrs {set _ $k='$v'}] " "]
        return "<input $output>"

ns_adp_registerscript input ::template::tag-input


<!DOCTYPE html>
 <form action="/action.tcl">
  Name: <input type="text" name="fname"><br>
  <input type="hidden" name="foo" value="bar">  
  <input type="submit" value="Submit">

page in browser:

<!DOCTYPE html>
 <form action="/action.tcl">
  Name: <input type='text' name='fname' class='visible'><br>
  <input type='text' name='foo' value='bar' class='hidden'>  
  <input type='submit' value='Submit' class='visible'>
Dear Gustaf

many thanks for the help! I'll give this a try.

all the best

Hi Gustaf

I got a chance to play with your code and it works quite well. A few comments/questions.

I had to add the following to deal with XHTML tags e.g. &lt;input... /&gt; as there was an additional forwardslash key in the attrs dict.
set attrs [dict remove $attrs / ]

The code does modify the original HTML slightly but I don't think this is an isue e.g. 'checked' gets changed to 'checked="checked"'. I haven't tested more complex input fields e.g. ones with onclick or file uploads etc. Ideally it would be great to leave these as-is, but I'm not sure if this is possible?

Another question I have: do you know of any way from within the tag-input proc to pass messages to/from the containing form? My goal here is to remove all hidden input fields from the form, and replace them with a single hidden field whose value will be stored in the session, and which gets submitted in the form.

best wishes

'checked' gets changed to 'checked="checked"'

to avoid this, handle Boolean attributes separately (as this is necessary also on other places, such as e.g. in the xowiki/tcl/form-field-procs).

... pass messages to/from the containing form
It is possible to overload also "outer" tags, build a stack of such tags with client specific code and query this from the inner tag handlers.


Thanks Gustaf!