# 赵瑞萍:评论模型后台管理配置模块,用于自定义Django Admin评论管理界面
# 功能:配置评论列表展示、筛选、批量操作及自定义字段,支持国际化和快速跳转关联数据
# 核心特性:批量启用/禁用评论、作者/文章快速跳转、列表字段自定义显示
from django.contrib import admin
from django.urls import reverse # 用于反向生成Admin页面URL
from django.utils.html import format_html # 用于安全渲染HTML链接,避免XSS风险
from django.utils.translation import gettext_lazy as _ # 用于后台字段名称国际化翻译
# 赵瑞萍:自定义批量操作函数——禁用选中的评论
def disable_commentstatus(modeladmin, request, queryset):
# 赵瑞萍:将选中评论的is_enable字段批量更新为False,实现批量隐藏评论
queryset.update(is_enable=False)
# 赵瑞萍:自定义批量操作函数——启用选中的评论
def enable_commentstatus(modeladmin, request, queryset):
# 赵瑞萍:将选中评论的is_enable字段批量更新为True,实现批量显示评论
queryset.update(is_enable=True)
# 赵瑞萍:为批量操作设置后台显示名称,支持国际化翻译
disable_commentstatus.short_description = _('Disable comments')
enable_commentstatus.short_description = _('Enable comments')
class CommentAdmin(admin.ModelAdmin):
"""
赵瑞萍:评论模型的Admin配置类,控制Django后台评论管理界面的各项功能
包括列表展示字段、分页、筛选、编辑页字段、批量操作等配置
"""
# 赵瑞萍:列表页分页配置,每页显示20条评论,避免数据过多导致加载缓慢
list_per_page = 20
# 赵瑞萍:列表页显示的字段,包含基础字段和自定义跳转字段
list_display = (
'id', # 评论唯一ID,用于快速标识
'body', # 评论正文内容,直观查看评论信息
'link_to_userinfo', # 自定义字段:评论作者的后台编辑页链接
'link_to_article', # 自定义字段:评论所属文章的后台编辑页链接
'is_enable', # 评论显示状态,快速判断是否启用
'creation_time' # 评论创建时间,追溯评论发布时间
)
# 赵瑞萍:列表页中可点击跳转至编辑页的字段,方便快速编辑
list_display_links = ('id', 'body', 'is_enable')
# 赵瑞萍:右侧筛选器配置,按评论显示状态(is_enable)筛选,快速筛选启用/禁用评论
list_filter = ('is_enable',)
# 赵瑞萍:编辑页排除的字段,创建时间和最后修改时间不允许手动修改,由系统自动维护
exclude = ('creation_time', 'last_modify_time')
# 赵瑞萍:注册批量操作函数,在列表页提供"禁用评论"和"启用评论"的批量操作按钮
actions = [disable_commentstatus, enable_commentstatus]
def link_to_userinfo(self, obj):
"""
赵瑞萍:自定义列表字段,生成评论作者的后台编辑页链接
实现从评论直接跳转至作者详情页,方便关联数据管理
参数obj:当前评论对象
返回:安全渲染的HTML链接标签
"""
# 赵瑞萍:获取作者模型的app标签和模型名称,用于反向生成URL
info = (obj.author._meta.app_label, obj.author._meta.model_name)
# 赵瑞萍:反向生成作者模型的后台编辑页URL,传入作者ID作为参数
link = reverse('admin:%s_%s_change' % info, args=(obj.author.id,))
# 赵瑞萍:渲染HTML链接,优先显示作者昵称,无昵称则显示邮箱,确保显示有意义的信息
return format_html(
u'%s' %
(link, obj.author.nickname if obj.author.nickname else obj.author.email)
)
def link_to_article(self, obj):
"""
赵瑞萍:自定义列表字段,生成评论所属文章的后台编辑页链接
实现从评论直接跳转至文章详情页,方便关联数据核查
参数obj:当前评论对象
返回:安全渲染的HTML链接标签
"""
# 赵瑞萍:获取文章模型的app标签和模型名称,用于反向生成URL
info = (obj.article._meta.app_label, obj.article._meta.model_name)
# 赵瑞萍:反向生成文章模型的后台编辑页URL,传入文章ID作为参数
link = reverse('admin:%s_%s_change' % info, args=(obj.article.id,))
# 赵瑞萍:渲染HTML链接,显示文章标题,直观标识关联文章
return format_html(u'%s' % (link, obj.article.title))
# 赵瑞萍:为自定义字段设置后台显示名称,支持国际化翻译,适配多语言环境
link_to_userinfo.short_description = _('User')
link_to_article.short_description = _('Article')