Wapp

Working with parameters with the same name
Login

Working with parameters with the same name

(1) By silas (silasdb) on 2024-01-09 00:50:11 [source]

ere!

First of all, thanks for this incredible framework! :-)

I'm building a small web application using wapp. I have some input fields that return results as multiple parameters with the same name. Example:

<select name="bicycles" multiple>
  <option value="specialized">Specialized</option>
  <option value="scott">Scott</option>
  <option value="gt">gt</option>
  ...
</select>

User can select multiple choices. If the user select the first two choices, generated query is:

bicycles=specialized&bicycles=scott

As you know, this is the standard way to return lists of things to the server and web languages and framework usually accept this and show the result as an array or vector.

wapp currently considers only the last parameter and the others are lost. This is done in line 589 of wapp.tcl:

          dict set wapp $nm [wappInt-decode-url [lindex $qsplit 1]]

I tried replacing dict set for dict lappend, but then single strings started to show surrounded by braces. So, I replaced that line with the following code:

          set p [wappInt-decode-url [lindex $qsplit 1]]
          if {[dict exists $wapp $nm]} {
            dict lappend wapp $nm $p
          } else {
            dict set wapp $nm $p
          }

... and it seems to solve the problem (returning to the caller of [wapp-param] as a list, but I didn't test deeply, so I don't know if there is any other side-effect. Of course, is up to the developer to know how to handle the response (as a string or a list).

What do you think of this? Any chance this change could be tested and maybe accepted? (Or maybe I'm just doing everything wrong?)

Thank you very much!

(2) By Stephan Beal (stephan) on 2024-11-20 12:08:24 in reply to 1 [link] [source]

I have some input fields that return results as multiple parameters with the same name.

FYI, Richard checked in an experimental change to support this:

/timeline?r=duplicate-parameters

It's not yet in the trunk, and is unlikely to reach there until/unless someone tries it out and confirms that it does the job without breaking anything.

(3.2) By silas (silasdb) on 2025-01-04 11:58:57 edited from 3.1 in reply to 2 [link] [source]

Hello stephan and drh! Thanks for considering that.

I discovered the approach I've suggested and that is being tested in the duplicate-parameters branch is problematic (at least for me). With this approach, it is impossible to see if the value received from the framework is a list or a string. Is Bob Alice one name or two people names? By solving this problem that way, maybe we are creating a more complicated problem?

So, I ended up using the former approach I told you in my first post (the one I first reproached). Instead of original line dict set wapp $nm [wappInt-decode-url [lindex $qsplit 1]], I replaced this line for:

dict lappend wapp $nm [wappInt-decode-url [lindex $qsplit 1]]

That way, I always receive a list that I can safely pass to [llength] to check how many items I have and pick the ones I'm interested with [lindex] or just use all of them.

Suggestions?

Thanks!