Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

#2311: New ComboBox widget for form fields [BOB] #3302

Open
wants to merge 24 commits into
base: main
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
24 commits
Select commit Hold shift + click to select a range
2651cd4
initial approach, from domain.py, not quite working
dave-kennedy-ecs Jan 2, 2025
f359a63
combobox in domain request organization contact
dave-kennedy-ecs Jan 6, 2025
4480e32
updated combobox widget to set proper data-default-value and set doma…
dave-kennedy-ecs Jan 6, 2025
3146dc0
applied widget to state territory
dave-kennedy-ecs Jan 6, 2025
560baed
linted
dave-kennedy-ecs Jan 6, 2025
bb5f61f
updated behavior of combobox, added state territory combobox
dave-kennedy-ecs Jan 10, 2025
0e2d62f
small improvement
dave-kennedy-ecs Jan 10, 2025
6283cad
state territory in org name address domain form
dave-kennedy-ecs Jan 10, 2025
462dae3
Merge branch 'main' into bob/2311-combo-boxes
dave-kennedy-ecs Jan 10, 2025
d411745
fixing test_export again
dave-kennedy-ecs Jan 10, 2025
b4505b3
lint
dave-kennedy-ecs Jan 10, 2025
ae6c461
added federal agency on domain page, and suborg on requesting entity …
dave-kennedy-ecs Jan 13, 2025
d54e57b
update federal agency drop down not to have any exclusions
dave-kennedy-ecs Jan 13, 2025
e2486c1
organization edit form - added state territory combobox
dave-kennedy-ecs Jan 14, 2025
ea509f6
uswds edits to combobox, default values for comboboxes, cleanup of co…
dave-kennedy-ecs Jan 14, 2025
1ca52b4
additional edits to uswds and to combobox.js to accomodate for empty …
dave-kennedy-ecs Jan 15, 2025
24e0243
fixed bug with portfolio requesting entity
dave-kennedy-ecs Jan 15, 2025
fabedda
modified combobox to handle error class
dave-kennedy-ecs Jan 15, 2025
74ef30b
fixed the 'other' problem in requesting entity form
dave-kennedy-ecs Jan 15, 2025
6a49f9e
requesting entity working - code still wip
dave-kennedy-ecs Jan 16, 2025
088140a
clean up of requesting entity
dave-kennedy-ecs Jan 16, 2025
f9fa877
cleanup and lint
dave-kennedy-ecs Jan 16, 2025
3708ef1
Merge branch 'main' into bob/2311-combo-boxes
dave-kennedy-ecs Jan 16, 2025
ba27880
removed default empty options from Checkboxes as they are only needed…
dave-kennedy-ecs Jan 17, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
18 changes: 3 additions & 15 deletions src/registrar/forms/domain.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@
from django import forms
from django.core.validators import MinValueValidator, MaxValueValidator, RegexValidator, MaxLengthValidator
from django.forms import formset_factory
from registrar.forms.utility.combobox import ComboboxWidget
from registrar.models import DomainRequest, FederalAgency
from phonenumber_field.widgets import RegionalPhoneNumberWidget
from registrar.models.suborganization import Suborganization
Expand Down Expand Up @@ -161,9 +162,10 @@ class DomainSuborganizationForm(forms.ModelForm):
"""Form for updating the suborganization"""

sub_organization = forms.ModelChoiceField(
label="Suborganization name",
queryset=Suborganization.objects.none(),
required=False,
widget=forms.Select(),
widget=ComboboxWidget,
)

class Meta:
Expand All @@ -178,20 +180,6 @@ def __init__(self, *args, **kwargs):
portfolio = self.instance.portfolio if self.instance else None
self.fields["sub_organization"].queryset = Suborganization.objects.filter(portfolio=portfolio)

# Set initial value
if self.instance and self.instance.sub_organization:
self.fields["sub_organization"].initial = self.instance.sub_organization

# Set custom form label
self.fields["sub_organization"].label = "Suborganization name"

# Use the combobox rather than the regular select widget
self.fields["sub_organization"].widget.template_name = "django/forms/widgets/combobox.html"

# Set data-default-value attribute
if self.instance and self.instance.sub_organization:
self.fields["sub_organization"].widget.attrs["data-default-value"] = self.instance.sub_organization.pk


class BaseNameserverFormset(forms.BaseFormSet):
def clean(self):
Expand Down
3 changes: 3 additions & 0 deletions src/registrar/forms/domain_request_wizard.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@
from django.core.validators import RegexValidator, MaxLengthValidator
from django.utils.safestring import mark_safe

from registrar.forms.utility.combobox import ComboboxWidget
from registrar.forms.utility.wizard_form_helper import (
RegistrarForm,
RegistrarFormSet,
Expand Down Expand Up @@ -257,6 +258,7 @@ class OrganizationContactForm(RegistrarForm):
required=False,
queryset=FederalAgency.objects.exclude(agency__in=excluded_agencies),
empty_label="--Select--",
widget=ComboboxWidget,
)
organization_name = forms.CharField(
label="Organization name",
Expand All @@ -280,6 +282,7 @@ class OrganizationContactForm(RegistrarForm):
error_messages={
"required": ("Select the state, territory, or military post where your organization is located.")
},
widget=ComboboxWidget,
)
zipcode = forms.CharField(
label="Zip code",
Expand Down
5 changes: 5 additions & 0 deletions src/registrar/forms/utility/combobox.py
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
from django.forms import Select


class ComboboxWidget(Select):
template_name = "django/forms/widgets/combobox.html"
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@
{{ name }}="{{ value }}"
{% endif %}
{% endfor %}
data-default-value="{% for group_name, group_choices, group_index in widget.optgroups %}{% for option in group_choices %}{% if option.selected %}{{ option.value }}{% endif %}{% endfor %}{% endfor %}"
>
{% include "django/forms/widgets/select.html" %}
</div>
Loading