第十一章 在线教育平台(xadmin的进阶开发)

xadmin的进阶开发

标签: django


userprofile 注册以及django的权限管理

  • 用户信息放入用户栏中(针对老版本的bug)

通过将userprofile继承与xadmin中plugin下面的UserAdmin ,并注册userprofile,同时注销User。

# _*_ encoding:utf-8 _*_

__author__ = 'wrj008'
__date__ = '2018/3/9 17:15'

import xadmin
from xadmin import views
from xadmin.plugins.auth import UserAdmin, User
from .models import EmailVerifyRecord, Banner

from users.models import UserProfile


class UserProfileAdmin(UserAdmin):
    pass


class BaseSetting(object):
    enable_themes = True
    use_bootswatch = True


class GloableSetting(object):
    site_title = '教育后台管理系统'
    site_footer = 'xiaojinzi'
    menu_style = 'accordion'


class EmailVerifyRecordAdmin(object):
    list_display = ['code', 'email', 'send_time', 'send_type']
    search_fields = ['code', 'email', 'send_time']
    list_filter = ['code', 'email', 'send_time', 'send_type']


class BannerAdmin(object):
    list_display = ['title', 'image', 'url', 'index', 'add_time']
    search_fields = ['title', 'image', 'url', 'index']
    list_filter = ['title', 'image', 'url', 'index', 'add_time']


xadmin.site.unregister(User)
xadmin.site.register(EmailVerifyRecord, EmailVerifyRecordAdmin)
xadmin.site.register(Banner, BannerAdmin)
xadmin.site.register(UserProfile, UserProfileAdmin)
xadmin.site.register(views.BaseAdminView, BaseSetting)
xadmin.site.register(views.CommAdminView, GloableSetting)

  • 另一种方式是通过在xadmin.auth中添加
from django.contrib.auth import get_user_model
User = get_user_model()
  • 用户的权限管理

通过对软件进行操作。

用户后台界面中的icon图片进行修改

django用的是font-awesome样式风格。 地址

在修改的adminx的下面添加
model_icon = 'fa fa-circle-o-notch fa-spin'
排序
ordering = ['-click_nums']
只读字段显示
readonly_fields = ['click_nums']
不显示字段(与上面会存在冲突)
exclude = ['']
下拉选择过多时,通过外键的主表添加字段,异步搜索呈现内容
relfield_style = 'fk-ajax'
列表中字段直接修改
list_editable = ['']

自定义列表返回数据,同一model两个注册管理器

  • inline操作

添加课程的同时在课程截界面添加章节信息。

class LessonAinline(object):
    model = Lesson
    extra = 0


class CourseAdmin(object):
    list_display = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image',
                    'add_time']
    search_fields = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image']
    list_filter = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image',
                   'add_time']
    inlines = [LessonAinline]

  • 同一model两个注册管理器

例如其中的轮播课程,可以分为两个列表页,其中一个是轮播课程界面,另一个是非轮播界面。

class BannerCourse(Course):
    """
    轮播图课程
    """
    class Meta:
        verbose_name = u'轮播图课程'
        verbose_name_plural = verbose_name
        proxy = True
# _*_ encoding:utf-8 _*_
from __future__ import unicode_literals
from datetime import datetime
from django.db import models

from organization.models import CourseOrg, Teacher

# Create your models here.


class Course(models.Model):
    course_org = models.ForeignKey(CourseOrg, verbose_name=u'课程机构')
    name = models.CharField(max_length=128, verbose_name=u'课程名称')
    desc = models.CharField(max_length=256, verbose_name=u'课程描述')
    category = models.CharField(default=u'后端开发', max_length=20, verbose_name=u'课程分类')
    detail = models.TextField(verbose_name=u'课程详情')
    degree = models.CharField(choices=(('cj', '初级'), ('zj', '中级'), ('gj', '高级')), max_length=2, verbose_name=u'课程难度')
    learn_time = models.IntegerField(default=0, verbose_name=u'课程时长')
    students = models.IntegerField(default=0, verbose_name=u'学习人数')
    fav_nums = models.IntegerField(default=0, verbose_name=u'收藏人数')
    click_nums = models.IntegerField(default=0, verbose_name=u'点击数')
    teacher = models.ForeignKey(Teacher, null=True, blank=True, verbose_name=u'教师外键')
    image = models.ImageField(upload_to='courses/%Y/%m', verbose_name=u'封面图', max_length=128)
    tag = models.CharField(default='', max_length=20, verbose_name=u'课程标签')
    youneed_know = models.CharField(default='', max_length=256, verbose_name=u'课程须知')
    is_banner = models.BooleanField(default=False, verbose_name=u'是否是广告栏')
    teacher_tell = models.CharField(default='', max_length=256, verbose_name=u'教师建议')
    add_time = models.DateTimeField(default=datetime.now, verbose_name=u'添加时间')

    class Meta:
        verbose_name = u'课程信息'
        verbose_name_plural = verbose_name

    def get_lesson_count(self):
        # 课程章节外键获取总数
        return self.lesson_set.all().count()

    def get_students_list(self):
        # 根据用户操作外键获取学习用户
        return self.usercourse_set.all()[:5]

    def ger_lesson_detail(self):
        # 获取所有的章节信息
        return self.lesson_set.all()

    def __unicode__(self):
        return self.name


class BannerCourse(Course):
    """
    轮播图课程
    """
    class Meta:
        verbose_name = u'轮播图课程'
        verbose_name_plural = verbose_name
        proxy = True


class Lesson(models.Model):
    course = models.ForeignKey(Course, verbose_name=u'章节外键')
    name = models.CharField(max_length=128, verbose_name=u'章节名称')
    add_time = models.DateTimeField(default=datetime.now, verbose_name=u'添加时间')

    class Meta:
        verbose_name = u'章节信息'
        verbose_name_plural = verbose_name

    def __unicode__(self):
        return self.name

    def get_video_info(self):
        # 获取所有视屏信息
        return self.video_set.all()


class Video(models.Model):
    lesson = models.ForeignKey(Lesson, verbose_name=u'视频')
    name = models.CharField(max_length=128, verbose_name=u'视频名称')
    url = models.CharField(default='', max_length=200, verbose_name=u'章节连接')
    learn_time = models.IntegerField(default=0, verbose_name=u'章节时长')
    add_time = models.DateTimeField(default=datetime.now, verbose_name=u'添加时间')

    class Meta:
        verbose_name = u'视频信息'
        verbose_name_plural = verbose_name

    def __unicode__(self):
        return self.name


class CourseResource(models.Model):
    course = models.ForeignKey(Course, verbose_name=u'资源')
    download = models.FileField(upload_to='course/resource/%Y/%m', verbose_name=u'下载地址', max_length=128)
    name = models.CharField(max_length=128, verbose_name=u'资源名称')
    add_time = models.DateTimeField(default=datetime.now, verbose_name=u'添加时间')

    class Meta:
        verbose_name = u'资源信息'
        verbose_name_plural = verbose_name

# _*_ encoding:utf-8 _*_

__author__ = 'wrj008'
__date__ = '2018/3/10 8:49'

import xadmin
from .models import Course, Lesson, Video, CourseResource, BannerCourse


class LessonAinline(object):
    model = Lesson
    extra = 0


class CourseAdmin(object):
    list_display = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image',
                    'add_time']
    search_fields = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image']
    list_filter = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image',
                   'add_time']
    inlines = [LessonAinline]

    def queryset(self):
        qs = super(CourseAdmin, self).queryset()
        qs = qs.filter(is_banner=False)
        return qs


class BannerCourseAdmin(object):
    list_display = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image',
                    'add_time']
    search_fields = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image']
    list_filter = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image',
                   'add_time']
    inlines = [LessonAinline]

    def queryset(self):
        qs = super(BannerCourseAdmin, self).queryset()
        qs = qs.filter(is_banner=True)
        return qs


class LessonAdmin(object):
    list_display = ['course', 'name', 'add_time']
    search_fields = ['course', 'name']
    list_filter = ['course', 'name', 'add_time']


class VideoAdmin(object):
    list_display = ['lesson', 'name', 'add_time']
    search_fields = ['lesson', 'name']
    list_filter = ['lesson', 'name', 'add_time']


class CourseResourceAdmin(object):
    list_display = ['course', 'download', 'name', 'add_time']
    search_fields = ['course', 'download', 'name']
    list_filter = ['course', 'download', 'name', 'add_time']


xadmin.site.register(Course, CourseAdmin)
xadmin.site.register(BannerCourse, BannerCourseAdmin)
xadmin.site.register(Lesson, LessonAdmin)
xadmin.site.register(Video, VideoAdmin)
xadmin.site.register(CourseResource, CourseResourceAdmin)

  • 函数显示
  def get_lesson_count(self):
        # 课程章节外键获取总数
        return self.lesson_set.all().count()

    get_lesson_count.short_description = '章节数'

    def go_to(self):
        from django.utils.safestring import mark_safe
        return mark_safe('跳转')
        
    
  • 页面自动刷新
class CourseAdmin(object):
    list_display = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image',
                    'add_time']
    search_fields = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image']
    list_filter = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image',
                   'add_time']
    inlines = [LessonAinline]
    refresh_times = [3, 5]

    def queryset(self):
        qs = super(CourseAdmin, self).queryset()
        qs = qs.filter(is_banner=False)
        return qs
  • 课程保存,机构中课程数量更新
class CourseAdmin(object):
    list_display = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image',
                    'add_time']
    search_fields = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image']
    list_filter = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image',
                   'add_time']
    inlines = [LessonAinline]
    refresh_times = [3, 5]

    def queryset(self):
        qs = super(CourseAdmin, self).queryset()
        qs = qs.filter(is_banner=False)
        return qs

    def save_models(self):
        """
        课程保存机构课程数更新
        """
        obj = self.new_obj
        obj.save()
        if obj.course_org is not None:
            course_org = obj.course_org
            course_org.course_nums = Course.objects.filter(course_org=course_org).count()
            course_org.save()

富文本集成

富文本
某个字段使用某种样式
style_fields = {'detail': 'ueditor'}
  • django-ueditor 开源富文本文件插件功能开发

github 开源项目地址

1.进入文件目录
cd ****
workon '虚拟环境'
python setup.py install

2.如果1没效果,则采用源码放入本地第三方保重,和xadmin一个文件夹下

压缩包中的DjangoUeditor文件


注册
INSTALLED_APPS = [
    'DjangoUeditor',
]
配置url
 # richtext url
    url(r'^ueditor/', include('DjangoUeditor.urls'))
    
model字段进行变更
from DjangoUeditor.models import UEditorField 

    detail = UEditorField(verbose_name=u'课程详情', width=600, height=300, toolbars="full", imagePath="course/ueditor/", filePath="course/ueditor/", default='')

plugin插件变更

# _*_ encoding:utf-8 _*_

__author__ = 'wrj008'
__date__ = '2018/3/19 16:41'
import xadmin
from xadmin.views import BaseAdminPlugin, CreateAdminView, ModelFormAdminView, UpdateAdminView
from DjangoUeditor.models import UEditorField
from DjangoUeditor.widgets import UEditorWidget
from django.conf import settings


class XadminUEditorWidget(UEditorWidget):
    def __init__(self,**kwargs):
        self.ueditor_options=kwargs
        self.Media.js = None
        super(XadminUEditorWidget,self).__init__(kwargs)


class UeditorPlugin(BaseAdminPlugin):

    def get_field_style(self, attrs, db_field, style, **kwargs):
        if style == 'ueditor':
            if isinstance(db_field, UEditorField):
                widget = db_field.formfield().widget
                param = {}
                param.update(widget.ueditor_settings)
                param.update(widget.attrs)
                return {'widget': XadminUEditorWidget(**param)}
        return attrs

    def block_extrahead(self, context, nodes):
        js = '' % (settings.STATIC_URL + "ueditor/ueditor.config.js")         #自己的静态目录
        js += '' % (settings.STATIC_URL + "ueditor/ueditor.all.min.js")   #自己的静态目录
        nodes.append(js)

xadmin.site.register_plugin(UeditorPlugin, UpdateAdminView)
xadmin.site.register_plugin(UeditorPlugin, CreateAdminView)

注册插件

将ueditor添加到plugin下的_init_中
PLUGINS = (
    ...
    'ueditor',
)

引用

class CourseAdmin(object):
    list_display = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image',
                    'add_time']
    search_fields = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image']
    list_filter = ['name', 'desc', 'detail', 'degree', 'learn_time', 'students', 'fav_nums', 'click_nums', 'image',
                   'add_time']
    inlines = [LessonAinline]
    refresh_times = [3, 5]
    style_fields = {'detail': 'ueditor'}

    def queryset(self):
        qs = super(CourseAdmin, self).queryset()
        qs = qs.filter(is_banner=False)
        return qs

    def save_models(self):
        """
        课程保存机构课程数更新
        """
        obj = self.new_obj
        obj.save()
        if obj.course_org is not None:
            course_org = obj.course_org
            course_org.course_nums = Course.objects.filter(course_org=course_org).count()
            course_org.save()
详情页面展示
{% autoescape off %} {{ course.detail }} {% endautoescape %}

  • 本篇博客原视频博主[慕课在线教育平台]
  • 本篇博客撰写人: XiaoJinZi 转载请注明出处
  • 学生能力有限 附上邮箱: [email protected] 不足以及误处请大佬指责

你可能感兴趣的:(第十一章 在线教育平台(xadmin的进阶开发))