Source code for web.utils.forms
# SPDX-License-Identifier: AGPL-3.0-or-later
#
# Eonvelope - a open-source self-hostable email archiving server
# Copyright (C) 2024 David Aderbauer & The Eonvelope Contributors
#
# This program is free software: you can redistribute it and/or modify
# it under the terms of the GNU Affero General Public License as
# published by the Free Software Foundation, either version 3 of the
# License, or (at your option) any later version.
#
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
# GNU Affero General Public License for more details.
#
# You should have received a copy of the GNU Affero General Public License
# along with this program. If not, see <https://www.gnu.org/licenses/>.
"""Module with custom form classes."""
from typing import Any
from django.forms import Form, ModelForm
from django.utils.translation import gettext_lazy as _
[docs]
class RequiredMarkerModelForm(ModelForm):
"""A slightly extended version of :class:`django.forms.ModelForm` that adds a marker to required fields."""
required_marker = _(" *")
[docs]
def __init__(self, *args: Any, **kwargs: Any) -> None:
"""Extended constructor adding :attr:`required_marker` to the required field labels."""
super().__init__(*args, **kwargs)
for field_name in self.fields:
if self.fields[field_name].required:
if self.fields[field_name].label is not None:
self.fields[field_name].label += self.required_marker # type: ignore[operator] # adding StrPromises is fine
else:
self.fields[field_name].label = self.required_marker
[docs]
class RequiredMarkerForm(Form):
"""A slightly extended version of :class:`django.forms.Form` that adds a marker to required fields."""
required_marker = _(" *")
[docs]
def __init__(self, *args: Any, **kwargs: Any) -> None:
"""Extended constructor adding :attr:`required_marker` to the required field labels."""
super().__init__(*args, **kwargs)
for field_name in self.fields:
if self.fields[field_name].required:
if self.fields[field_name].label is not None:
self.fields[field_name].label += self.required_marker # type: ignore[operator] # adding StrPromises is fine
else:
self.fields[field_name].label = self.required_marker