Как встроенную редактировать профиль пользователя Django в интерфейсе администратора?
-
25-09-2019 - |
Вопрос
Если вы хотите сохранить дополнительную информацию о пользователе (Django.contrib.auth.models.user) в Django, вы можете использовать Nifty auth_profile_module для подключения модели профиля ". Затем каждый пользователь получает профиль. Все это описано здесь:
- http://docs.djangoProject.com/en/dev/topics/auth/#storing-additional-information-about-users
- http://www.djangobook.com/en/1.0/Chapter12/#cn222.
Теперь, скажем, я создал приложение под названием учетные записи с моделью, называемой userprofile и зарегистрировал ее в качестве модели профиля для моих пользователей. Как мне встроить редактирование профиля в интерфейсе администратора для редактирования пользователей (или наоборот)?
Решение 3
Ну, оказывается, что это довольно просто, как только вы знаете, как это сделать. Это мой myapp / аккаунты / admin.py:
from django.contrib import admin
from myapp.accounts.models import UserProfile
from django.contrib.auth.models import User
class UserProfileInline(admin.StackedInline):
model = UserProfile
max_num = 1
can_delete = False
class AccountsUserAdmin(admin.UserAdmin):
inlines = [UserProfileInline]
# unregister old user admin
admin.site.unregister(User)
# register new user admin that includes a UserProfile
admin.site.register(User, AccountsUserAdmin)
По умолчанию admin.UserAdmin
ModelAdmin Class для пользователей незарегистрирован и новый указывающий встроенный UserProfile
зарегистрирован на своем месте. Просто думал, что я должен поделиться.
Другие советы
Я вызываю слегка улучшенную версию решения ANDRÉ, так как он нарушает список представления в списке в / admin / auth / user /:
from django.contrib import admin
from member.models import UserProfile
from django.contrib.auth.models import User
from django.contrib.auth.admin import UserAdmin as AuthUserAdmin
class UserProfileInline(admin.StackedInline):
model = UserProfile
max_num = 1
can_delete = False
class UserAdmin(AuthUserAdmin):
inlines = [UserProfileInline]
# unregister old user admin
admin.site.unregister(User)
# register new user admin
admin.site.register(User, UserAdmin)
Я предлагаю еще одно улучшение решения Роберта:
from django.contrib import admin
from member.models import UserProfile
from django.contrib.auth.models import User
from django.contrib.auth.admin import UserAdmin as AuthUserAdmin
class UserProfileInline(admin.StackedInline):
model = UserProfile
max_num = 1
can_delete = False
class UserAdmin(AuthUserAdmin):
def add_view(self, *args, **kwargs):
self.inlines = []
return super(UserAdmin, self).add_view(*args, **kwargs)
def change_view(self, *args, **kwargs):
self.inlines = [UserProfileInline]
return super(UserAdmin, self).change_view(*args, **kwargs)
# unregister old user admin
admin.site.unregister(User)
# register new user admin
admin.site.register(User, UserAdmin)
Без этого изменения в UserAdmin раздел пользовательской пользовательской настройки будет отображаться на экране «Добавить пользователя», который просто должен просить имя пользователя и пароль. И если вы измените любой из данных профиля на этом экране (вдали от по умолчанию), прежде чем сохранить, вы получите ошибку базы данных «дубликатов ключей».
Вы должны учитывать форму добавления и изменения. В противном случае вы получите пользователь, нельзя не ошибку при попытке создать пользователя. Следующее было проверено и работает в 1.3:
class TeamInline(admin.StackedInline):
model = Team
fk_name = 'user'
max_num = 1
can_delete = False
class TeamUserAdmin(UserAdmin):
list_display = ('username', 'email', 'company', 'expertise', 'contact_email', 'contact_phone', 'twitter', 'facebook', 'last_login_short', 'options')
list_select_related = True
def add_view(self, *args, **kwargs):
self.inline_instances = []
return super(TeamUserAdmin, self).add_view(*args, **kwargs)
def change_view(self, *args, **kwargs):
self.inline_instances.append(TeamInline(self.model, self.admin_site))
return super(TeamUserAdmin, self).change_view(*args, **kwargs)