From 974d14534ca6bc12352c08576af5628e3f042652 Mon Sep 17 00:00:00 2001 From: Mariusz Felisiak Date: Fri, 13 Jan 2017 12:34:33 +0100 Subject: [PATCH] Fixed #27723 -- Set MultiWidget's subwidgets input type from attrs argument. Regression in b52c73008a9d67e9ddbb841872dc15cdd3d6ee01. --- django/forms/widgets.py | 3 +++ tests/forms_tests/widget_tests/test_multiwidget.py | 13 +++++++++++++ 2 files changed, 16 insertions(+) diff --git a/django/forms/widgets.py b/django/forms/widgets.py index 801067ee386..a2f674fcdd4 100644 --- a/django/forms/widgets.py +++ b/django/forms/widgets.py @@ -808,9 +808,12 @@ class MultiWidget(Widget): value = self.decompress(value) final_attrs = context['widget']['attrs'] + input_type = final_attrs.pop('type', None) id_ = final_attrs.get('id') subwidgets = [] for i, widget in enumerate(self.widgets): + if input_type is not None: + widget.input_type = input_type widget_name = '%s_%s' % (name, i) try: widget_value = value[i] diff --git a/tests/forms_tests/widget_tests/test_multiwidget.py b/tests/forms_tests/widget_tests/test_multiwidget.py index a7cd8e0d5d8..bf9ef38a6be 100644 --- a/tests/forms_tests/widget_tests/test_multiwidget.py +++ b/tests/forms_tests/widget_tests/test_multiwidget.py @@ -118,6 +118,19 @@ class MultiWidgetTest(WidgetTest): '' )) + def test_constructor_attrs_with_type(self): + attrs = {'type': 'number'} + widget = MyMultiWidget(widgets=(TextInput, TextInput()), attrs=attrs) + self.check_html(widget, 'code', ['1', '2'], html=( + '' + '' + )) + widget = MyMultiWidget(widgets=(TextInput(attrs), TextInput(attrs)), attrs={'class': 'bar'}) + self.check_html(widget, 'code', ['1', '2'], html=( + '' + '' + )) + def test_value_omitted_from_data(self): widget = MyMultiWidget(widgets=(TextInput(), TextInput())) self.assertIs(widget.value_omitted_from_data({}, {}, 'field'), True)