Update user edit view to CBV. Remove user group's view helper functions.
This commit is contained in:
@@ -8,7 +8,7 @@ from .api_views import (
|
||||
)
|
||||
from .views import (
|
||||
GroupCreateView, GroupDeleteView, GroupEditView, GroupListView,
|
||||
GroupMembersView, UserGroupsView, UserListView
|
||||
GroupMembersView, UserEditView, UserGroupsView, UserListView
|
||||
)
|
||||
|
||||
urlpatterns = patterns(
|
||||
@@ -30,7 +30,7 @@ urlpatterns = patterns(
|
||||
|
||||
url(r'^user/list/$', UserListView.as_view(), name='user_list'),
|
||||
url(r'^user/add/$', 'user_add', name='user_add'),
|
||||
url(r'^user/(?P<user_id>\d+)/edit/$', 'user_edit', name='user_edit'),
|
||||
url(r'^user/(?P<pk>\d+)/edit/$', UserEditView.as_view(), name='user_edit'),
|
||||
url(r'^user/(?P<user_id>\d+)/delete/$', 'user_delete', name='user_delete'),
|
||||
url(
|
||||
r'^user/multiple/delete/$', 'user_multiple_delete',
|
||||
|
||||
@@ -39,40 +39,19 @@ class UserListView(SingleObjectListView):
|
||||
).exclude(is_staff=True).order_by('last_name', 'first_name')
|
||||
|
||||
|
||||
def user_edit(request, user_id):
|
||||
Permission.check_permissions(request.user, (permission_user_edit,))
|
||||
user = get_object_or_404(User, pk=user_id)
|
||||
class UserEditView(SingleObjectEditView):
|
||||
fields = ('username', 'first_name', 'last_name', 'email', 'is_active',)
|
||||
post_action_redirect = reverse_lazy('user_management:user_list')
|
||||
queryset = get_user_model().objects.filter(
|
||||
is_superuser=False, is_staff=False
|
||||
)
|
||||
view_permission = permission_user_edit
|
||||
|
||||
if user.is_superuser or user.is_staff:
|
||||
messages.error(
|
||||
request,
|
||||
_(
|
||||
'Super user and staff user editing is not allowed, use the '
|
||||
'admin interface for these cases.'
|
||||
)
|
||||
)
|
||||
return HttpResponseRedirect(
|
||||
request.META.get(
|
||||
'HTTP_REFERER', reverse(settings.LOGIN_REDIRECT_URL)
|
||||
)
|
||||
)
|
||||
|
||||
if request.method == 'POST':
|
||||
form = UserForm(instance=user, data=request.POST)
|
||||
if form.is_valid():
|
||||
form.save()
|
||||
messages.success(
|
||||
request, _('User "%s" updated successfully.') % user
|
||||
)
|
||||
return HttpResponseRedirect(reverse('user_management:user_list'))
|
||||
else:
|
||||
form = UserForm(instance=user)
|
||||
|
||||
return render_to_response('appearance/generic_form.html', {
|
||||
'title': _('Edit user: %s') % user,
|
||||
'form': form,
|
||||
'object': user,
|
||||
}, context_instance=RequestContext(request))
|
||||
def get_extra_context(self):
|
||||
return {
|
||||
'object': self.get_object(),
|
||||
'title': _('Edit user: %s') % self.get_object(),
|
||||
}
|
||||
|
||||
|
||||
def user_add(request):
|
||||
@@ -241,8 +220,10 @@ def user_set_password(request, user_id=None, user_id_list=None):
|
||||
elif len(users) > 1:
|
||||
context['title'] = _('Reseting password for users: %s') % ', '.join([unicode(d) for d in users])
|
||||
|
||||
return render_to_response('appearance/generic_form.html', context,
|
||||
context_instance=RequestContext(request))
|
||||
return render_to_response(
|
||||
'appearance/generic_form.html', context,
|
||||
context_instance=RequestContext(request)
|
||||
)
|
||||
|
||||
|
||||
def user_multiple_set_password(request):
|
||||
@@ -251,14 +232,6 @@ def user_multiple_set_password(request):
|
||||
)
|
||||
|
||||
|
||||
def get_user_groups(user):
|
||||
return Group.objects.filter(user=user)
|
||||
|
||||
|
||||
def get_user_non_groups(user):
|
||||
return Group.objects.exclude(user=user)
|
||||
|
||||
|
||||
class UserGroupsView(AssignRemoveView):
|
||||
decode_content_type = True
|
||||
left_list_title = _('Available groups')
|
||||
@@ -279,12 +252,12 @@ class UserGroupsView(AssignRemoveView):
|
||||
|
||||
def left_list(self):
|
||||
return AssignRemoveView.generate_choices(
|
||||
get_user_non_groups(self.get_object())
|
||||
Group.objects.exclude(user=self.get_object())
|
||||
)
|
||||
|
||||
def right_list(self):
|
||||
return AssignRemoveView.generate_choices(
|
||||
get_user_groups(self.get_object())
|
||||
Group.objects.filter(user=self.get_object())
|
||||
)
|
||||
|
||||
def remove(self, item):
|
||||
|
||||
Reference in New Issue
Block a user