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

5.0: Update django.forms.boundfield and django.forms.utils #2118

Merged
merged 10 commits into from
May 3, 2024
8 changes: 6 additions & 2 deletions django-stubs/forms/boundfield.pyi
Original file line number Diff line number Diff line change
Expand Up @@ -4,15 +4,15 @@ from typing import Any, overload
from django.forms.fields import Field
from django.forms.forms import BaseForm
from django.forms.renderers import BaseRenderer
from django.forms.utils import ErrorList
from django.forms.utils import ErrorList, RenderableFieldMixin
from django.forms.widgets import Widget
from django.utils.functional import _StrOrPromise, cached_property
from django.utils.safestring import SafeString
from typing_extensions import TypeAlias

_AttrsT: TypeAlias = dict[str, str | bool]

class BoundField:
class BoundField(RenderableFieldMixin):
form: BaseForm
field: Field
name: str
Expand All @@ -21,6 +21,7 @@ class BoundField:
html_initial_id: str
label: _StrOrPromise
help_text: _StrOrPromise
renderer: BaseRenderer
def __init__(self, form: BaseForm, field: Field, name: str) -> None: ...
@cached_property
def subwidgets(self) -> list[BoundWidget]: ...
Expand All @@ -33,6 +34,9 @@ class BoundField:
def __getitem__(self, idx: slice) -> list[BoundWidget]: ...
@property
def errors(self) -> ErrorList: ...
@property
def template_name(self) -> str: ...
def get_context(self) -> dict[str, Any]: ...
JaeHyuckSa marked this conversation as resolved.
Show resolved Hide resolved
def as_widget(
self, widget: Widget | None = ..., attrs: _AttrsT | None = ..., only_initial: bool = ...
) -> SafeString: ...
Expand Down
14 changes: 11 additions & 3 deletions django-stubs/forms/utils.pyi
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
from collections import UserList
from collections.abc import Mapping, Sequence
from datetime import datetime
from typing import Any
from typing import Any, Callable

from django.core.exceptions import ValidationError
from django.core.files.uploadedfile import UploadedFile
Expand All @@ -26,8 +26,16 @@ class RenderableMixin:
context: dict[str, Any] | None = ...,
renderer: BaseRenderer | type[BaseRenderer] | None = ...,
) -> SafeString: ...
__str__ = render
JaeHyuckSa marked this conversation as resolved.
Show resolved Hide resolved
__html__ = render

__str__: Callable[..., SafeString] = ...
__html__: Callable[..., SafeString] = ...

class RenderableFieldMixin(RenderableMixin):
def as_field_group(self) -> SafeString: ...
def as_hidden(self) -> SafeString: ...
def as_widget(self) -> SafeString: ...
__str__: Callable[..., SafeString]
JaeHyuckSa marked this conversation as resolved.
Show resolved Hide resolved
__html__: Callable[..., SafeString]

class RenderableFormMixin(RenderableMixin):
def as_p(self) -> SafeString: ...
Expand Down
4 changes: 4 additions & 0 deletions scripts/django_tests_settings.py
Original file line number Diff line number Diff line change
Expand Up @@ -11,3 +11,7 @@
]

STATIC_URL = "static/"


GDAL_LIBRARY_PATH = "/opt/homebrew/opt/gdal/lib/libgdal.dylib"
GEOS_LIBRARY_PATH = "/opt/homebrew/opt/geos/lib/libgeos_c.dylib"
7 changes: 0 additions & 7 deletions scripts/stubtest/allowlist_todo_django50.txt
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,6 @@ django.contrib.gis.db.models.Prefetch.get_current_querysets
django.contrib.gis.db.models.Q.identity
django.contrib.gis.db.models.When.allowed_default
django.contrib.gis.forms.BaseForm._html_output
django.contrib.gis.forms.BoundField.get_context
django.contrib.gis.forms.BoundField.template_name
django.contrib.gis.forms.ClearableFileInput.checked
django.contrib.gis.forms.fields_for_model
django.contrib.gis.geos.prototypes.io.DEFAULT_TRIM_VALUE
Expand Down Expand Up @@ -93,16 +91,11 @@ django.db.models.sql.query.Query.join
django.db.models.sql.query.Query.resolve_lookup_value
django.db.models.sql.query.Query.setup_joins
django.forms.BaseForm._html_output
django.forms.BoundField.get_context
django.forms.BoundField.template_name
django.forms.ClearableFileInput.checked
django.forms.boundfield.BoundField.get_context
django.forms.boundfield.BoundField.template_name
django.forms.fields_for_model
django.forms.forms.BaseForm._html_output
django.forms.models.fields_for_model
django.forms.renderers.BaseRenderer.field_template_name
django.forms.renderers.Jinja2DivFormRenderer.__init__
django.forms.utils.RenderableFieldMixin
django.forms.widgets.ClearableFileInput.checked
django.template.autoreload
Loading