mirror of
				https://github.com/netbox-community/netbox.git
				synced 2024-05-10 07:54:54 +00:00 
			
		
		
		
	#8054: Allow replacing default static choices
This commit is contained in:
		| @@ -174,11 +174,11 @@ EXEMPT_VIEW_PERMISSIONS = ['*'] | |||||||
|  |  | ||||||
| ## FIELD_CHOICES | ## FIELD_CHOICES | ||||||
|  |  | ||||||
| Default: Empty dictionary | Some static choice fields on models can be configured with custom values. This is done by defining `FIELD_CHOICES` as a dictionary mapping model fields to their choices. Each choice in the list must have a database value and a human-friendly label, and may optionally specify a color. (A list of available colors is provided below.) | ||||||
|  |  | ||||||
| Some static choice fields on models can be configured with custom values. This is done by defining `FIELD_CHOICES` as a dictionary mapping model fields to their choices list. Each choice in the list must have a database value and a human-friendly label, and may optionally specify a color. (A list of available colors is provided below.) | The choices provided can either replace the stock choices provided by NetBox, or append to them. To _replace_ the available choices, specify the app, model, and field name separated by dots. For example, the site model would be referenced as `dcim.Site.status`. To _extend_ the available choices, append a plus sign to the end of this string (e.g. `dcim.Site.status+`). | ||||||
|  |  | ||||||
| For example, to specify a custom set of choices for the site status field: | For example, the following configuration would replace the default site status choices with the options Foo, Bar, and Baz: | ||||||
|  |  | ||||||
| ```python | ```python | ||||||
| FIELD_CHOICES = { | FIELD_CHOICES = { | ||||||
| @@ -190,7 +190,15 @@ FIELD_CHOICES = { | |||||||
| } | } | ||||||
| ``` | ``` | ||||||
|  |  | ||||||
| These will be appended to the stock choices for the field. | Appending a plus sign to the field identifier would instead _add_ these choices to the ones already offered: | ||||||
|  |  | ||||||
|  | ```python | ||||||
|  | FIELD_CHOICES = { | ||||||
|  |     'dcim.Site.status+': ( | ||||||
|  |         ... | ||||||
|  |     ) | ||||||
|  | } | ||||||
|  | ``` | ||||||
|  |  | ||||||
| The following model field support configurable choices: | The following model field support configurable choices: | ||||||
|  |  | ||||||
|   | |||||||
| @@ -8,12 +8,14 @@ class ChoiceSetMeta(type): | |||||||
|     def __new__(mcs, name, bases, attrs): |     def __new__(mcs, name, bases, attrs): | ||||||
|  |  | ||||||
|         # Extend static choices with any configured choices |         # Extend static choices with any configured choices | ||||||
|         key = attrs.get('key') |         replace_key = attrs.get('key') | ||||||
|         if key: |         extend_key = f'{replace_key}+' if replace_key else None | ||||||
|             try: |         if replace_key and replace_key in settings.FIELD_CHOICES: | ||||||
|                 attrs['CHOICES'].extend(settings.FIELD_CHOICES[key]) |             # Replace the stock choices | ||||||
|             except KeyError: |             attrs['CHOICES'] = settings.FIELD_CHOICES[replace_key] | ||||||
|                 pass |         elif extend_key and extend_key in settings.FIELD_CHOICES: | ||||||
|  |             # Extend the stock choices | ||||||
|  |             attrs['CHOICES'].extend(settings.FIELD_CHOICES[extend_key]) | ||||||
|  |  | ||||||
|         # Define choice tuples and color maps |         # Define choice tuples and color maps | ||||||
|         attrs['_choices'] = [] |         attrs['_choices'] = [] | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user