Introduce UserConfigForm for managing user preferences

This commit is contained in:
jeremystretch
2021-12-21 16:29:01 -05:00
parent 5e32c69e0e
commit 70f257b1ea
8 changed files with 103 additions and 105 deletions
+65 -1
View File
@@ -2,7 +2,9 @@ from django import forms
from django.contrib.auth.forms import AuthenticationForm, PasswordChangeForm as DjangoPasswordChangeForm
from utilities.forms import BootstrapMixin, DateTimePicker
from .models import Token
from utilities.paginator import EnhancedPaginator
from utilities.utils import flatten_dict
from .models import Token, UserConfig
class LoginForm(BootstrapMixin, AuthenticationForm):
@@ -13,6 +15,68 @@ class PasswordChangeForm(BootstrapMixin, DjangoPasswordChangeForm):
pass
def get_page_lengths():
return [
(v, str(v)) for v in EnhancedPaginator.default_page_lengths
]
class UserConfigForm(BootstrapMixin, forms.ModelForm):
pagination__per_page = forms.TypedChoiceField(
label='Page length',
coerce=lambda val: int(val),
choices=get_page_lengths,
required=False
)
ui__colormode = forms.ChoiceField(
label='Color mode',
choices=(
('light', 'Light'),
('dark', 'Dark'),
),
required=False
)
extras__configcontext__format = forms.ChoiceField(
label='ConfigContext format',
choices=(
('json', 'JSON'),
('yaml', 'YAML'),
),
required=False
)
class Meta:
model = UserConfig
fields = ()
fieldsets = (
('User Interface', (
'pagination__per_page',
'ui__colormode',
)),
('Miscellaneous', (
'extras__configcontext__format',
)),
)
def __init__(self, *args, instance=None, **kwargs):
# Get initial data from UserConfig instance
initial_data = flatten_dict(instance.data, separator='__')
kwargs['initial'] = initial_data
super().__init__(*args, instance=instance, **kwargs)
def save(self, *args, **kwargs):
# Set UserConfig data
for field_name, value in self.cleaned_data.items():
pref_name = field_name.replace('__', '.')
print(f'{pref_name}: {value}')
self.instance.set(pref_name, value, commit=False)
return super().save(*args, **kwargs)
class TokenForm(BootstrapMixin, forms.ModelForm):
key = forms.CharField(
required=False,
+13 -17
View File
@@ -19,7 +19,7 @@ from extras.models import ObjectChange
from extras.tables import ObjectChangeTable
from netbox.config import get_config
from utilities.forms import ConfirmationForm
from .forms import LoginForm, PasswordChangeForm, TokenForm
from .forms import LoginForm, PasswordChangeForm, TokenForm, UserConfigForm
from .models import Token
@@ -137,32 +137,28 @@ class UserConfigView(LoginRequiredMixin, View):
template_name = 'users/preferences.html'
def get(self, request):
userconfig = request.user.config
form = UserConfigForm(instance=userconfig)
return render(request, self.template_name, {
'preferences': request.user.config.all(),
'form': form,
'active_tab': 'preferences',
})
def post(self, request):
userconfig = request.user.config
data = userconfig.all()
form = UserConfigForm(request.POST, instance=userconfig)
# Delete selected preferences
if "_delete" in request.POST:
for key in request.POST.getlist('pk'):
if key in data:
userconfig.clear(key)
# Update specific values
elif "_update" in request.POST:
for key in request.POST:
if not key.startswith('_') and not key.startswith('csrf'):
for value in request.POST.getlist(key):
userconfig.set(key, value)
if form.is_valid():
form.save()
userconfig.save()
messages.success(request, "Your preferences have been updated.")
messages.success(request, "Your preferences have been updated.")
return redirect('user:preferences')
return redirect('user:preferences')
return render(request, self.template_name, {
'form': form,
'active_tab': 'preferences',
})
class ChangePasswordView(LoginRequiredMixin, View):