[1.8.x] Fixed #21516 -- Updated imports paths for some formset functions/classes.
Since refs #21489, FormSet classes and factories are exposed on the
django.forms package.
Backport of 455034d4df
from master
This commit is contained in:
parent
2bfd80d845
commit
42f2546742
|
@ -1671,7 +1671,7 @@ templates used by the :class:`ModelAdmin` views:
|
|||
changelist page if :attr:`~ModelAdmin.list_editable` is used. To use a
|
||||
custom formset, for example::
|
||||
|
||||
from django.forms.models import BaseModelFormSet
|
||||
from django.forms import BaseModelFormSet
|
||||
|
||||
class MyAdminFormSet(BaseModelFormSet):
|
||||
pass
|
||||
|
|
|
@ -20,7 +20,7 @@ form::
|
|||
You might want to allow the user to create several articles at once. To create
|
||||
a formset out of an ``ArticleForm`` you would do::
|
||||
|
||||
>>> from django.forms.formsets import formset_factory
|
||||
>>> from django.forms import formset_factory
|
||||
>>> ArticleFormSet = formset_factory(ArticleForm)
|
||||
|
||||
You now have created a formset named ``ArticleFormSet``. The formset gives you
|
||||
|
@ -60,7 +60,7 @@ number of forms it generates from the initial data. Let's take a look at an
|
|||
example::
|
||||
|
||||
>>> import datetime
|
||||
>>> from django.forms.formsets import formset_factory
|
||||
>>> from django.forms import formset_factory
|
||||
>>> from myapp.forms import ArticleForm
|
||||
>>> ArticleFormSet = formset_factory(ArticleForm, extra=2)
|
||||
>>> formset = ArticleFormSet(initial=[
|
||||
|
@ -93,7 +93,7 @@ Limiting the maximum number of forms
|
|||
The ``max_num`` parameter to :func:`~django.forms.formsets.formset_factory`
|
||||
gives you the ability to limit the number of forms the formset will display::
|
||||
|
||||
>>> from django.forms.formsets import formset_factory
|
||||
>>> from django.forms import formset_factory
|
||||
>>> from myapp.forms import ArticleForm
|
||||
>>> ArticleFormSet = formset_factory(ArticleForm, extra=2, max_num=1)
|
||||
>>> formset = ArticleFormSet()
|
||||
|
@ -130,7 +130,7 @@ Validation with a formset is almost identical to a regular ``Form``. There is
|
|||
an ``is_valid`` method on the formset to provide a convenient way to validate
|
||||
all forms in the formset::
|
||||
|
||||
>>> from django.forms.formsets import formset_factory
|
||||
>>> from django.forms import formset_factory
|
||||
>>> from myapp.forms import ArticleForm
|
||||
>>> ArticleFormSet = formset_factory(ArticleForm)
|
||||
>>> data = {
|
||||
|
@ -251,8 +251,7 @@ Custom formset validation
|
|||
A formset has a ``clean`` method similar to the one on a ``Form`` class. This
|
||||
is where you define your own validation that works at the formset level::
|
||||
|
||||
>>> from django.forms.formsets import BaseFormSet
|
||||
>>> from django.forms.formsets import formset_factory
|
||||
>>> from django.forms import BaseFormSet, formset_factory
|
||||
>>> from myapp.forms import ArticleForm
|
||||
|
||||
>>> class BaseArticleFormSet(BaseFormSet):
|
||||
|
@ -307,7 +306,7 @@ If ``validate_max=True`` is passed to
|
|||
that the number of forms in the data set, minus those marked for
|
||||
deletion, is less than or equal to ``max_num``.
|
||||
|
||||
>>> from django.forms.formsets import formset_factory
|
||||
>>> from django.forms import formset_factory
|
||||
>>> from myapp.forms import ArticleForm
|
||||
>>> ArticleFormSet = formset_factory(ArticleForm, max_num=1, validate_max=True)
|
||||
>>> data = {
|
||||
|
@ -351,7 +350,7 @@ If ``validate_min=True`` is passed to
|
|||
that the number of forms in the data set, minus those marked for
|
||||
deletion, is greater than or equal to ``min_num``.
|
||||
|
||||
>>> from django.forms.formsets import formset_factory
|
||||
>>> from django.forms import formset_factory
|
||||
>>> from myapp.forms import ArticleForm
|
||||
>>> ArticleFormSet = formset_factory(ArticleForm, min_num=3, validate_min=True)
|
||||
>>> data = {
|
||||
|
@ -393,7 +392,7 @@ Default: ``False``
|
|||
|
||||
Lets you create a formset with the ability to order::
|
||||
|
||||
>>> from django.forms.formsets import formset_factory
|
||||
>>> from django.forms import formset_factory
|
||||
>>> from myapp.forms import ArticleForm
|
||||
>>> ArticleFormSet = formset_factory(ArticleForm, can_order=True)
|
||||
>>> formset = ArticleFormSet(initial=[
|
||||
|
@ -453,7 +452,7 @@ Default: ``False``
|
|||
|
||||
Lets you create a formset with the ability to select forms for deletion::
|
||||
|
||||
>>> from django.forms.formsets import formset_factory
|
||||
>>> from django.forms import formset_factory
|
||||
>>> from myapp.forms import ArticleForm
|
||||
>>> ArticleFormSet = formset_factory(ArticleForm, can_delete=True)
|
||||
>>> formset = ArticleFormSet(initial=[
|
||||
|
@ -538,8 +537,7 @@ accomplished. The formset base class provides an ``add_fields`` method. You
|
|||
can simply override this method to add your own fields or even redefine the
|
||||
default fields/attributes of the order and deletion fields::
|
||||
|
||||
>>> from django.forms.formsets import BaseFormSet
|
||||
>>> from django.forms.formsets import formset_factory
|
||||
>>> from django.forms import BaseFormSet, formset_factory
|
||||
>>> from myapp.forms import ArticleForm
|
||||
>>> class BaseArticleFormSet(BaseFormSet):
|
||||
... def add_fields(self, form, index):
|
||||
|
@ -561,7 +559,7 @@ Using a formset inside a view is as easy as using a regular ``Form`` class.
|
|||
The only thing you will want to be aware of is making sure to use the
|
||||
management form inside the template. Let's look at a sample view::
|
||||
|
||||
from django.forms.formsets import formset_factory
|
||||
from django.forms import formset_factory
|
||||
from django.shortcuts import render_to_response
|
||||
from myapp.forms import ArticleForm
|
||||
|
||||
|
@ -638,7 +636,7 @@ borrow much of its behavior from forms. With that said you are able to use
|
|||
more than one formset to be sent to a view without name clashing. Lets take
|
||||
a look at how this might be accomplished::
|
||||
|
||||
from django.forms.formsets import formset_factory
|
||||
from django.forms import formset_factory
|
||||
from django.shortcuts import render_to_response
|
||||
from myapp.forms import ArticleForm, BookForm
|
||||
|
||||
|
|
|
@ -703,7 +703,7 @@ You can create forms from a given model using the standalone function
|
|||
definition. This may be more convenient if you do not have many customizations
|
||||
to make::
|
||||
|
||||
>>> from django.forms.models import modelform_factory
|
||||
>>> from django.forms import modelform_factory
|
||||
>>> from myapp.models import Book
|
||||
>>> BookForm = modelform_factory(Book, fields=("author", "title"))
|
||||
|
||||
|
@ -734,7 +734,7 @@ Like :doc:`regular formsets </topics/forms/formsets>`, Django provides a couple
|
|||
of enhanced formset classes that make it easy to work with Django models. Let's
|
||||
reuse the ``Author`` model from above::
|
||||
|
||||
>>> from django.forms.models import modelformset_factory
|
||||
>>> from django.forms import modelformset_factory
|
||||
>>> from myapp.models import Author
|
||||
>>> AuthorFormSet = modelformset_factory(Author, fields=('name', 'title'))
|
||||
|
||||
|
@ -784,7 +784,7 @@ queryset that includes all objects in the model (e.g.,
|
|||
Alternatively, you can create a subclass that sets ``self.queryset`` in
|
||||
``__init__``::
|
||||
|
||||
from django.forms.models import BaseModelFormSet
|
||||
from django.forms import BaseModelFormSet
|
||||
from myapp.models import Author
|
||||
|
||||
class BaseAuthorFormSet(BaseModelFormSet):
|
||||
|
@ -952,7 +952,7 @@ Using a model formset in a view
|
|||
Model formsets are very similar to formsets. Let's say we want to present a
|
||||
formset to edit ``Author`` model instances::
|
||||
|
||||
from django.forms.models import modelformset_factory
|
||||
from django.forms import modelformset_factory
|
||||
from django.shortcuts import render_to_response
|
||||
from myapp.models import Author
|
||||
|
||||
|
@ -986,7 +986,7 @@ the unique constraints on your model (either ``unique``, ``unique_together`` or
|
|||
on a ``ModelFormSet`` and maintain this validation, you must call the parent
|
||||
class's ``clean`` method::
|
||||
|
||||
from django.forms.models import BaseModelFormSet
|
||||
from django.forms import BaseModelFormSet
|
||||
|
||||
class MyModelFormSet(BaseModelFormSet):
|
||||
def clean(self):
|
||||
|
@ -1002,7 +1002,7 @@ have already been created for each ``Form``. Modifying a value in
|
|||
to modify a value in ``ModelFormSet.clean()`` you must modify
|
||||
``form.instance``::
|
||||
|
||||
from django.forms.models import BaseModelFormSet
|
||||
from django.forms import BaseModelFormSet
|
||||
|
||||
class MyModelFormSet(BaseModelFormSet):
|
||||
def clean(self):
|
||||
|
@ -1020,7 +1020,7 @@ Using a custom queryset
|
|||
As stated earlier, you can override the default queryset used by the model
|
||||
formset::
|
||||
|
||||
from django.forms.models import modelformset_factory
|
||||
from django.forms import modelformset_factory
|
||||
from django.shortcuts import render_to_response
|
||||
from myapp.models import Author
|
||||
|
||||
|
@ -1124,7 +1124,7 @@ you have these two models::
|
|||
If you want to create a formset that allows you to edit books belonging to
|
||||
a particular author, you could do this::
|
||||
|
||||
>>> from django.forms.models import inlineformset_factory
|
||||
>>> from django.forms import inlineformset_factory
|
||||
>>> BookFormSet = inlineformset_factory(Author, Book, fields=('title',))
|
||||
>>> author = Author.objects.get(name='Mike Royko')
|
||||
>>> formset = BookFormSet(instance=author)
|
||||
|
@ -1148,7 +1148,7 @@ When overriding methods on ``InlineFormSet``, you should subclass
|
|||
|
||||
For example, if you want to override ``clean()``::
|
||||
|
||||
from django.forms.models import BaseInlineFormSet
|
||||
from django.forms import BaseInlineFormSet
|
||||
|
||||
class CustomInlineFormSet(BaseInlineFormSet):
|
||||
def clean(self):
|
||||
|
@ -1163,7 +1163,7 @@ See also :ref:`model-formsets-overriding-clean`.
|
|||
Then when you create your inline formset, pass in the optional argument
|
||||
``formset``::
|
||||
|
||||
>>> from django.forms.models import inlineformset_factory
|
||||
>>> from django.forms import inlineformset_factory
|
||||
>>> BookFormSet = inlineformset_factory(Author, Book, fields=('title',),
|
||||
... formset=CustomInlineFormSet)
|
||||
>>> author = Author.objects.get(name='Mike Royko')
|
||||
|
|
Loading…
Reference in New Issue