mirror of
				https://github.com/django/django.git
				synced 2025-10-26 15:16:09 +00:00 
			
		
		
		
	[4.0.x] Fixed #33334 -- Alphabetized form and model fields in reference docs.
Backport of d75c387f46 from main
			
			
This commit is contained in:
		
				
					committed by
					
						 Mariusz Felisiak
						Mariusz Felisiak
					
				
			
			
				
	
			
			
			
						parent
						
							2fa95bfbd4
						
					
				
				
					commit
					306fbf197a
				
			| @@ -418,39 +418,6 @@ For each field, we describe the default widget used if you don't specify | |||||||
|         time the field's form is initialized, in addition to during rendering. |         time the field's form is initialized, in addition to during rendering. | ||||||
|         Defaults to an empty list. |         Defaults to an empty list. | ||||||
|  |  | ||||||
| ``TypedChoiceField`` |  | ||||||
| -------------------- |  | ||||||
|  |  | ||||||
| .. class:: TypedChoiceField(**kwargs) |  | ||||||
|  |  | ||||||
|     Just like a :class:`ChoiceField`, except :class:`TypedChoiceField` takes two |  | ||||||
|     extra arguments, :attr:`coerce` and :attr:`empty_value`. |  | ||||||
|  |  | ||||||
|     * Default widget: :class:`Select` |  | ||||||
|     * Empty value: Whatever you've given as :attr:`empty_value`. |  | ||||||
|     * Normalizes to: A value of the type provided by the :attr:`coerce` |  | ||||||
|       argument. |  | ||||||
|     * Validates that the given value exists in the list of choices and can be |  | ||||||
|       coerced. |  | ||||||
|     * Error message keys: ``required``, ``invalid_choice`` |  | ||||||
|  |  | ||||||
|     Takes extra arguments: |  | ||||||
|  |  | ||||||
|     .. attribute:: coerce |  | ||||||
|  |  | ||||||
|         A function that takes one argument and returns a coerced value. Examples |  | ||||||
|         include the built-in ``int``, ``float``, ``bool`` and other types. Defaults |  | ||||||
|         to an identity function. Note that coercion happens after input |  | ||||||
|         validation, so it is possible to coerce to a value not present in |  | ||||||
|         ``choices``. |  | ||||||
|  |  | ||||||
|     .. attribute:: empty_value |  | ||||||
|  |  | ||||||
|         The value to use to represent "empty." Defaults to the empty string; |  | ||||||
|         ``None`` is another common choice here. Note that this value will not be |  | ||||||
|         coerced by the function given in the ``coerce`` argument, so choose it |  | ||||||
|         accordingly. |  | ||||||
|  |  | ||||||
| ``DateField`` | ``DateField`` | ||||||
| ------------- | ------------- | ||||||
|  |  | ||||||
| @@ -677,6 +644,40 @@ For each field, we describe the default widget used if you don't specify | |||||||
|     Takes two optional arguments for validation, ``max_value`` and ``min_value``. |     Takes two optional arguments for validation, ``max_value`` and ``min_value``. | ||||||
|     These control the range of values permitted in the field. |     These control the range of values permitted in the field. | ||||||
|  |  | ||||||
|  | ``GenericIPAddressField`` | ||||||
|  | ------------------------- | ||||||
|  |  | ||||||
|  | .. class:: GenericIPAddressField(**kwargs) | ||||||
|  |  | ||||||
|  |     A field containing either an IPv4 or an IPv6 address. | ||||||
|  |  | ||||||
|  |     * Default widget: :class:`TextInput` | ||||||
|  |     * Empty value: ``''`` (an empty string) | ||||||
|  |     * Normalizes to: A string. IPv6 addresses are normalized as described below. | ||||||
|  |     * Validates that the given value is a valid IP address. | ||||||
|  |     * Error message keys: ``required``, ``invalid`` | ||||||
|  |  | ||||||
|  |     The IPv6 address normalization follows :rfc:`4291#section-2.2` section 2.2, | ||||||
|  |     including using the IPv4 format suggested in paragraph 3 of that section, like | ||||||
|  |     ``::ffff:192.0.2.0``. For example, ``2001:0::0:01`` would be normalized to | ||||||
|  |     ``2001::1``, and ``::ffff:0a0a:0a0a`` to ``::ffff:10.10.10.10``. All characters | ||||||
|  |     are converted to lowercase. | ||||||
|  |  | ||||||
|  |     Takes two optional arguments: | ||||||
|  |  | ||||||
|  |     .. attribute:: protocol | ||||||
|  |  | ||||||
|  |         Limits valid inputs to the specified protocol. | ||||||
|  |         Accepted values are ``both`` (default), ``IPv4`` | ||||||
|  |         or ``IPv6``. Matching is case insensitive. | ||||||
|  |  | ||||||
|  |     .. attribute:: unpack_ipv4 | ||||||
|  |  | ||||||
|  |         Unpacks IPv4 mapped addresses like ``::ffff:192.0.2.1``. | ||||||
|  |         If this option is enabled that address would be unpacked to | ||||||
|  |         ``192.0.2.1``. Default is disabled. Can only be used | ||||||
|  |         when ``protocol`` is set to ``'both'``. | ||||||
|  |  | ||||||
| ``ImageField`` | ``ImageField`` | ||||||
| -------------- | -------------- | ||||||
|  |  | ||||||
| @@ -821,40 +822,6 @@ For each field, we describe the default widget used if you don't specify | |||||||
|         it is a useful way to format data from a client-side widget for |         it is a useful way to format data from a client-side widget for | ||||||
|         submission to the server. |         submission to the server. | ||||||
|  |  | ||||||
| ``GenericIPAddressField`` |  | ||||||
| ------------------------- |  | ||||||
|  |  | ||||||
| .. class:: GenericIPAddressField(**kwargs) |  | ||||||
|  |  | ||||||
|     A field containing either an IPv4 or an IPv6 address. |  | ||||||
|  |  | ||||||
|     * Default widget: :class:`TextInput` |  | ||||||
|     * Empty value: ``''`` (an empty string) |  | ||||||
|     * Normalizes to: A string. IPv6 addresses are normalized as described below. |  | ||||||
|     * Validates that the given value is a valid IP address. |  | ||||||
|     * Error message keys: ``required``, ``invalid`` |  | ||||||
|  |  | ||||||
|     The IPv6 address normalization follows :rfc:`4291#section-2.2` section 2.2, |  | ||||||
|     including using the IPv4 format suggested in paragraph 3 of that section, like |  | ||||||
|     ``::ffff:192.0.2.0``. For example, ``2001:0::0:01`` would be normalized to |  | ||||||
|     ``2001::1``, and ``::ffff:0a0a:0a0a`` to ``::ffff:10.10.10.10``. All characters |  | ||||||
|     are converted to lowercase. |  | ||||||
|  |  | ||||||
|     Takes two optional arguments: |  | ||||||
|  |  | ||||||
|     .. attribute:: protocol |  | ||||||
|  |  | ||||||
|         Limits valid inputs to the specified protocol. |  | ||||||
|         Accepted values are ``both`` (default), ``IPv4`` |  | ||||||
|         or ``IPv6``. Matching is case insensitive. |  | ||||||
|  |  | ||||||
|     .. attribute:: unpack_ipv4 |  | ||||||
|  |  | ||||||
|         Unpacks IPv4 mapped addresses like ``::ffff:192.0.2.1``. |  | ||||||
|         If this option is enabled that address would be unpacked to |  | ||||||
|         ``192.0.2.1``. Default is disabled. Can only be used |  | ||||||
|         when ``protocol`` is set to ``'both'``. |  | ||||||
|  |  | ||||||
| ``MultipleChoiceField`` | ``MultipleChoiceField`` | ||||||
| ----------------------- | ----------------------- | ||||||
|  |  | ||||||
| @@ -872,28 +839,6 @@ For each field, we describe the default widget used if you don't specify | |||||||
|  |  | ||||||
|     Takes one extra required argument, ``choices``, as for :class:`ChoiceField`. |     Takes one extra required argument, ``choices``, as for :class:`ChoiceField`. | ||||||
|  |  | ||||||
| ``TypedMultipleChoiceField`` |  | ||||||
| ---------------------------- |  | ||||||
|  |  | ||||||
| .. class:: TypedMultipleChoiceField(**kwargs) |  | ||||||
|  |  | ||||||
|     Just like a :class:`MultipleChoiceField`, except :class:`TypedMultipleChoiceField` |  | ||||||
|     takes two extra arguments, ``coerce`` and ``empty_value``. |  | ||||||
|  |  | ||||||
|     * Default widget: :class:`SelectMultiple` |  | ||||||
|     * Empty value: Whatever you've given as ``empty_value`` |  | ||||||
|     * Normalizes to: A list of values of the type provided by the ``coerce`` |  | ||||||
|       argument. |  | ||||||
|     * Validates that the given values exists in the list of choices and can be |  | ||||||
|       coerced. |  | ||||||
|     * Error message keys: ``required``, ``invalid_choice`` |  | ||||||
|  |  | ||||||
|     The ``invalid_choice`` error message may contain ``%(value)s``, which will be |  | ||||||
|     replaced with the selected choice. |  | ||||||
|  |  | ||||||
|     Takes two extra arguments, ``coerce`` and ``empty_value``, as for |  | ||||||
|     :class:`TypedChoiceField`. |  | ||||||
|  |  | ||||||
| ``NullBooleanField`` | ``NullBooleanField`` | ||||||
| -------------------- | -------------------- | ||||||
|  |  | ||||||
| @@ -997,6 +942,61 @@ For each field, we describe the default widget used if you don't specify | |||||||
|     localization is enabled. See also :doc:`format localization |     localization is enabled. See also :doc:`format localization | ||||||
|     </topics/i18n/formatting>`. |     </topics/i18n/formatting>`. | ||||||
|  |  | ||||||
|  | ``TypedChoiceField`` | ||||||
|  | -------------------- | ||||||
|  |  | ||||||
|  | .. class:: TypedChoiceField(**kwargs) | ||||||
|  |  | ||||||
|  |     Just like a :class:`ChoiceField`, except :class:`TypedChoiceField` takes two | ||||||
|  |     extra arguments, :attr:`coerce` and :attr:`empty_value`. | ||||||
|  |  | ||||||
|  |     * Default widget: :class:`Select` | ||||||
|  |     * Empty value: Whatever you've given as :attr:`empty_value`. | ||||||
|  |     * Normalizes to: A value of the type provided by the :attr:`coerce` | ||||||
|  |       argument. | ||||||
|  |     * Validates that the given value exists in the list of choices and can be | ||||||
|  |       coerced. | ||||||
|  |     * Error message keys: ``required``, ``invalid_choice`` | ||||||
|  |  | ||||||
|  |     Takes extra arguments: | ||||||
|  |  | ||||||
|  |     .. attribute:: coerce | ||||||
|  |  | ||||||
|  |         A function that takes one argument and returns a coerced value. Examples | ||||||
|  |         include the built-in ``int``, ``float``, ``bool`` and other types. Defaults | ||||||
|  |         to an identity function. Note that coercion happens after input | ||||||
|  |         validation, so it is possible to coerce to a value not present in | ||||||
|  |         ``choices``. | ||||||
|  |  | ||||||
|  |     .. attribute:: empty_value | ||||||
|  |  | ||||||
|  |         The value to use to represent "empty." Defaults to the empty string; | ||||||
|  |         ``None`` is another common choice here. Note that this value will not be | ||||||
|  |         coerced by the function given in the ``coerce`` argument, so choose it | ||||||
|  |         accordingly. | ||||||
|  |  | ||||||
|  | ``TypedMultipleChoiceField`` | ||||||
|  | ---------------------------- | ||||||
|  |  | ||||||
|  | .. class:: TypedMultipleChoiceField(**kwargs) | ||||||
|  |  | ||||||
|  |     Just like a :class:`MultipleChoiceField`, except :class:`TypedMultipleChoiceField` | ||||||
|  |     takes two extra arguments, ``coerce`` and ``empty_value``. | ||||||
|  |  | ||||||
|  |     * Default widget: :class:`SelectMultiple` | ||||||
|  |     * Empty value: Whatever you've given as ``empty_value`` | ||||||
|  |     * Normalizes to: A list of values of the type provided by the ``coerce`` | ||||||
|  |       argument. | ||||||
|  |     * Validates that the given values exists in the list of choices and can be | ||||||
|  |       coerced. | ||||||
|  |     * Error message keys: ``required``, ``invalid_choice`` | ||||||
|  |  | ||||||
|  |     The ``invalid_choice`` error message may contain ``%(value)s``, which will be | ||||||
|  |     replaced with the selected choice. | ||||||
|  |  | ||||||
|  |     Takes two extra arguments, ``coerce`` and ``empty_value``, as for | ||||||
|  |     :class:`TypedChoiceField`. | ||||||
|  |  | ||||||
| ``URLField`` | ``URLField`` | ||||||
| ------------ | ------------ | ||||||
|  |  | ||||||
|   | |||||||
| @@ -1118,6 +1118,37 @@ when :attr:`~django.forms.Field.localize` is ``False`` or | |||||||
|     information on the difference between the two, see Python's documentation |     information on the difference between the two, see Python's documentation | ||||||
|     for the :mod:`decimal` module. |     for the :mod:`decimal` module. | ||||||
|  |  | ||||||
|  | ``GenericIPAddressField`` | ||||||
|  | ------------------------- | ||||||
|  |  | ||||||
|  | .. class:: GenericIPAddressField(protocol='both', unpack_ipv4=False, **options) | ||||||
|  |  | ||||||
|  | An IPv4 or IPv6 address, in string format (e.g. ``192.0.2.30`` or | ||||||
|  | ``2a02:42fe::4``). The default form widget for this field is a | ||||||
|  | :class:`~django.forms.TextInput`. | ||||||
|  |  | ||||||
|  | The IPv6 address normalization follows :rfc:`4291#section-2.2` section 2.2, | ||||||
|  | including using the IPv4 format suggested in paragraph 3 of that section, like | ||||||
|  | ``::ffff:192.0.2.0``. For example, ``2001:0::0:01`` would be normalized to | ||||||
|  | ``2001::1``, and ``::ffff:0a0a:0a0a`` to ``::ffff:10.10.10.10``. All characters | ||||||
|  | are converted to lowercase. | ||||||
|  |  | ||||||
|  | .. attribute:: GenericIPAddressField.protocol | ||||||
|  |  | ||||||
|  |     Limits valid inputs to the specified protocol. | ||||||
|  |     Accepted values are ``'both'`` (default), ``'IPv4'`` | ||||||
|  |     or ``'IPv6'``. Matching is case insensitive. | ||||||
|  |  | ||||||
|  | .. attribute:: GenericIPAddressField.unpack_ipv4 | ||||||
|  |  | ||||||
|  |     Unpacks IPv4 mapped addresses like ``::ffff:192.0.2.1``. | ||||||
|  |     If this option is enabled that address would be unpacked to | ||||||
|  |     ``192.0.2.1``. Default is disabled. Can only be used | ||||||
|  |     when ``protocol`` is set to ``'both'``. | ||||||
|  |  | ||||||
|  | If you allow for blank values, you have to allow for null values since blank | ||||||
|  | values are stored as null. | ||||||
|  |  | ||||||
| ``ImageField`` | ``ImageField`` | ||||||
| -------------- | -------------- | ||||||
|  |  | ||||||
| @@ -1169,37 +1200,6 @@ The default form widget for this field is a :class:`~django.forms.NumberInput` | |||||||
| when :attr:`~django.forms.Field.localize` is ``False`` or | when :attr:`~django.forms.Field.localize` is ``False`` or | ||||||
| :class:`~django.forms.TextInput` otherwise. | :class:`~django.forms.TextInput` otherwise. | ||||||
|  |  | ||||||
| ``GenericIPAddressField`` |  | ||||||
| ------------------------- |  | ||||||
|  |  | ||||||
| .. class:: GenericIPAddressField(protocol='both', unpack_ipv4=False, **options) |  | ||||||
|  |  | ||||||
| An IPv4 or IPv6 address, in string format (e.g. ``192.0.2.30`` or |  | ||||||
| ``2a02:42fe::4``). The default form widget for this field is a |  | ||||||
| :class:`~django.forms.TextInput`. |  | ||||||
|  |  | ||||||
| The IPv6 address normalization follows :rfc:`4291#section-2.2` section 2.2, |  | ||||||
| including using the IPv4 format suggested in paragraph 3 of that section, like |  | ||||||
| ``::ffff:192.0.2.0``. For example, ``2001:0::0:01`` would be normalized to |  | ||||||
| ``2001::1``, and ``::ffff:0a0a:0a0a`` to ``::ffff:10.10.10.10``. All characters |  | ||||||
| are converted to lowercase. |  | ||||||
|  |  | ||||||
| .. attribute:: GenericIPAddressField.protocol |  | ||||||
|  |  | ||||||
|     Limits valid inputs to the specified protocol. |  | ||||||
|     Accepted values are ``'both'`` (default), ``'IPv4'`` |  | ||||||
|     or ``'IPv6'``. Matching is case insensitive. |  | ||||||
|  |  | ||||||
| .. attribute:: GenericIPAddressField.unpack_ipv4 |  | ||||||
|  |  | ||||||
|     Unpacks IPv4 mapped addresses like ``::ffff:192.0.2.1``. |  | ||||||
|     If this option is enabled that address would be unpacked to |  | ||||||
|     ``192.0.2.1``. Default is disabled. Can only be used |  | ||||||
|     when ``protocol`` is set to ``'both'``. |  | ||||||
|  |  | ||||||
| If you allow for blank values, you have to allow for null values since blank |  | ||||||
| values are stored as null. |  | ||||||
|  |  | ||||||
| ``JSONField`` | ``JSONField`` | ||||||
| ------------- | ------------- | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user