Skip to content

Commit

Permalink
Merge pull request #816 from aminalaee/fix-selectfield-backwards-compat
Browse files Browse the repository at this point in the history
Fix SelectField choice backwards compatibility
  • Loading branch information
azmeuk authored Nov 1, 2023
2 parents b059f2b + b63b9ac commit 0247f4c
Show file tree
Hide file tree
Showing 2 changed files with 35 additions and 5 deletions.
10 changes: 8 additions & 2 deletions src/wtforms/fields/choices.py
Original file line number Diff line number Diff line change
Expand Up @@ -49,7 +49,13 @@ def __iter__(self):
_form=None,
_meta=self.meta,
)
for i, (value, label, checked, render_kw) in enumerate(self.iter_choices()):
for i, choice in enumerate(self.iter_choices()):
if len(choice) == 4:
value, label, checked, render_kw = choice
else:
value, label, checked = choice
render_kw = {}

opt = self._Option(
label=label, id="%s-%d" % (self.id, i), **opts, **render_kw
)
Expand Down Expand Up @@ -141,7 +147,7 @@ def pre_validate(self, form):
if self.choices is None:
raise TypeError(self.gettext("Choices cannot be None."))

for _, _, match, _ in self.iter_choices():
for _, _, match, *_ in self.iter_choices():
if match:
break
else:
Expand Down
30 changes: 27 additions & 3 deletions src/wtforms/widgets/core.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
import warnings

from markupsafe import escape
from markupsafe import Markup

Expand Down Expand Up @@ -334,7 +336,7 @@ class Select:
The field must provide an `iter_choices()` method which the widget will
call on rendering; this method must yield tuples of
`(value, label, selected, render_kw)`.
`(value, label, selected)` or `(value, label, selected, render_kw)`.
It also must provide a `has_groups()` method which tells whether choices
are divided into groups, and if they do, the field must have an
`iter_groups()` method that yields tuples of `(label, choices)`, where
Expand All @@ -358,11 +360,33 @@ def __call__(self, field, **kwargs):
if field.has_groups():
for group, choices in field.iter_groups():
html.append("<optgroup %s>" % html_params(label=group))
for val, label, selected, render_kw in choices:
for choice in choices:
if len(choice) == 4:
val, label, selected, render_kw = choice
else:
warnings.warn(
"'iter_groups' is expected to return 4 items tuple since "
"wtforms 3.1, this will be mandatory in wtforms 3.2",
DeprecationWarning,
stacklevel=2,
)
val, label, selected = choice
render_kw = {}
html.append(self.render_option(val, label, selected, **render_kw))
html.append("</optgroup>")
else:
for val, label, selected, render_kw in field.iter_choices():
for choice in field.iter_choices():
if len(choice) == 4:
val, label, selected, render_kw = choice
else:
warnings.warn(
"'iter_groups' is expected to return 4 items tuple since "
"wtforms 3.1, this will be mandatory in wtforms 3.2",
DeprecationWarning,
stacklevel=2,
)
val, label, selected = choice
render_kw = {}
html.append(self.render_option(val, label, selected, **render_kw))
html.append("</select>")
return Markup("".join(html))
Expand Down

0 comments on commit 0247f4c

Please sign in to comment.