Django项目:CRM(客户关系管理系统)--25--17PerfectCRM实现King_admin单列排序
登陆密码设置参考
http://www.cnblogs.com/ujq3/p/8553784.html
1 {#table_data_list.html#} 2 {## ————————08PerfectCRM实现King_admin显示注册表的字段表头————————#} 3 4 {% extends 'king_master/king_index.html' %} {#继承模板#} 5 {% load kingadmin_tags %} {#通过自己定义标签获取中文,Django中利用filter与simple_tag为前端自定义函数的实现方法#} 6 7 {% block right-container-content %} 8 9 {#调用kingadmin_tags里的方法 获取 base_admin的值 #} 10 <h4>{% get_model_verbose_name admin_obj.model %}</h4> 11 12 13 14 {## ————————15PerfectCRM实现King_admin多条件过滤————————#} 15 {#判断 crm/kingadmin.py 里class CustomerAdmin(BaseAdmin):有没有使用list_filter = ('source',) #} 16 {% if admin_obj.list_filter %} 17 <div class="row"> 18 <form> 19 {#循环 上面 list_filter = ('source',) 的字段 #} 20 {% for filter_column in admin_obj.list_filter %} 21 <div class="col-lg-1">{#最多12份 空间 #} 22 <div>{{ filter_column }}</div> 23 24 {#到后端取值,传参数到后端, kingadmin/templatetags/kingadmin_tags.py的def get_filter_field (filter_column,admin_obj): #} 25 <div>{% get_filter_field filter_column admin_obj %}</div> 26 </div> 27 {% endfor %} 28 <div> 29 <input type="submit" class="btn btn-success" value="过滤"> 30 </div> 31 32 {## ————————17PerfectCRM实现King_admin单列排序————————#} 33 <div> 34 {# 隐藏 #} {# 过滤后排序功能 #} 35 <input type="hidden" name="_o" value="{% get_current_orderby_key request %}"> 36 </div> 37 {## ————————17PerfectCRM实现King_admin单列排序————————#} 38 39 </form> 40 </div> 41 {% endif %} 42 {## ————————15PerfectCRM实现King_admin多条件过滤————————#} 43 44 45 46 47 <table class="table table-hover"> 48 <thead> 49 <tr> 50 51 {## ————————17PerfectCRM实现King_admin单列排序————————#} 52 {#循环调用kingadmin/base_admin里的class BaseAdmin下的list_display = () 方法#} 53 {# {% for column in admin_obj.list_display %}#} 54 {# <th>{{ column }}</th>#} 55 {# {% endfor %}#} 56 {# #} 57 {% for column in admin_obj.list_display %} 58 {# <th>{{ column }}</th>#} {#过滤功能1#} 59 {#排序功能1#} 60 <th> 61 {# <a href="?_o={{ column }}">{{ column }}</a>#} {#http://127.0.0.1:8000/kingadmin/crm/customer/?_o=qq#} 62 {## kingadmin排序功能#} 63 {# <a href="?_o={% get_orderby_key request column %}">{{ column }}</a>#} 64 65 {## kingadmin排序功能#} {# 过滤后排序功能 #} 66 <a href="?_o={% get_orderby_key request column %}{% generate_filter_url admin_obj %}">{{ column }}</a> 67 68 {#显示排序图标#} 69 {% display_order_by_icon request column %} 70 71 </th> 72 {#排序功能1#} 73 {% endfor %} 74 {## ————————17PerfectCRM实现King_admin单列排序————————#} 75 76 77 </tr> 78 </thead> 79 80 {## ————————09PerfectCRM实现King_admin显示注册表的内容————————#} 81 <tbody> 82 {#循环调用kingadmin/views 里的def table_data_list下的admin_obj.querysets #} 83 {% for obj in admin_obj.querysets %} 84 <tr> 85 {#通过kingadmin_tags在后台处理 再传到前端 #} 86 {#调用kingadmin/templateags/kingadmin_tags 里的def build_table_row(admin_obj,obj):#} 87 {% build_table_row admin_obj obj %} 88 </tr> 89 {% endfor %} 90 </tbody> 91 {## ————————09PerfectCRM实现King_admin显示注册表的内容————————#} 92 93 </table> 94 95 {## ————————12PerfectCRM实现King_admin分页上下页————————#} 96 {# <div class="row">#} 97 {# <div class="pagination">#} 98 {# <span class="step-links">#} 99 {# {% if admin_obj.querysets.has_previous %}#} 100 {##} 101 {## ————————15PerfectCRM实现King_admin多条件过滤————————#} 102 {# <a href="?page={{ admin_obj.querysets.previous_page_number }}#} 103 {# <a href="?page={{ admin_obj.querysets.previous_page_number }}{% generate_filter_url admin_obj %}">上一页 </a>#} 104 {## ————————15PerfectCRM实现King_admin多条件过滤————————#} 105 {##} 106 {# {% endif %}#} 107 {##} 108 {# <span class="current">#} 109 {# 第{{ admin_obj.querysets.number }}页,共{{ admin_obj.querysets.paginator.num_pages }}页#} 110 {# </span>#} 111 {##} 112 {# {% if admin_obj.querysets.has_next %}#} 113 {##} 114 {## ————————15PerfectCRM实现King_admin多条件过滤————————#} 115 {# <a href="?page={{ admin_obj.querysets.next_page_number }}#} 116 {# <a href="?page={{ admin_obj.querysets.next_page_number }}{% generate_filter_url admin_obj %}">下一页</a>#} 117 {## ————————15PerfectCRM实现King_admin多条件过滤————————#} 118 {##} 119 {# {% endif %}#} 120 {# </span>#} 121 {# </div>#} 122 {# </div>#} 123 {## ————————12PerfectCRM实现King_admin分页上下页————————#} 124 125 {## ————————13PerfectCRM实现King_admin分页页数————————#} 126 {# <nav aria-label="...">#} 127 {# <ul class="pagination">#} 128 {# <li class="disabled"></li>#} 129 {# {% for page in admin_obj.querysets.paginator.page_range %} {#循环 分页 范围#} 130 {##} 131 {# {% if page == admin_obj.querysets.number %} {#当前页高亮,否则不加高亮#} 132 {# <li class="active">#} 133 {# {% else %}#} 134 {# <li >#} 135 {# {% endif %}#} 136 {##} 137 {#后台拼接返回,kingadmin/templatetags/kingadmin_tags.py 里def generate_filter_url(admin_obj):#} 138 {# <a href="?page={{ page }}{% generate_filter_url admin_obj %}">{{ page }}</a>#} 139 {# </li>#} 140 {# {% endfor %}#} 141 {# </ul>#} 142 {# </nav>#} 143 {## ————————13PerfectCRM实现King_admin分页页数————————#} 144 145 {## ————————14PerfectCRM实现King_admin分页的省略显示————————#} 146 <div class="row panel-body"> 147 <nav aria-label="..."> 148 <ul class="pagination"> 149 <!--如果有上一页--> 150 {% if admin_obj.querysets.has_previous %} 151 {## ————————17PerfectCRM实现King_admin单列排序————————#} 152 {# <li><a href="?page={{ admin_obj.querysets.previous_page_number }}{% generate_filter_url admin_obj %}"#} 153 {# aria-label="Previous"><span aria-hidden="true">«</span></a></li>#} 154 155 {#获取上一个数字#} {# kingadmin排序功能 # 过滤后排序功能#排序#} {#分页#} 156 <li><a href="?page={{ admin_obj.querysets.previous_page_number }}{% generate_order_by_url request %}{% generate_filter_url admin_obj %}" 157 aria-label="Previous"><span aria-hidden="true">上页</span></a></li> 158 {## ————————17PerfectCRM实现King_admin单列排序————————#} 159 160 {% else %} 161 <li class="disabled"> 162 <a href="#" aria-label="Previous"><span aria-hidden="true">«</span></a></li> 163 {% endif %} 164 165 <!--#分页的省略显示 kingadmin/templatetags/kingadmin_tags.py里def pag_omit(request,admin_obj):--> 166 {% pag_omit request admin_obj %} 167 168 <!--如果有下一页--> 169 {% if admin_obj.querysets.has_next %} 170 {## ————————17PerfectCRM实现King_admin单列排序————————#} 171 {# <li><a href="?page={{ admin_obj.querysets.next_page_number }}{% generate_filter_url admin_obj %}"#} 172 {# aria-label="Previous"><span aria-hidden="true">»</span></a></li>#} 173 174 <li><a href="?page={{ admin_obj.querysets.next_page_number }}{% generate_order_by_url request %}{% generate_filter_url admin_obj %}" 175 aria-label="Previous"><span aria-hidden="true">下页</span></a></li> 176 {## ————————17PerfectCRM实现King_admin单列排序————————#} 177 178 {% else %} 179 <li class="disabled"><a href="#" aria-label="Previous"><span aria-hidden="true">»</span></a> 180 </li> 181 {% endif %} 182 </ul> 183 </nav> 184 </div> 185 {## ————————14PerfectCRM实现King_admin分页的省略显示————————#} 186 187 188 {% endblock %} 189 {## ————————08PerfectCRM实现King_admin显示注册表的字段表头————————#}
1 #views 2 3 # ————————02PerfectCRM创建ADMIN页面———————— 4 from django.shortcuts import render 5 6 # ————————04PerfectCRM实现King_admin注册功能———————— 7 # from django import conf #配置文件 8 # print("dj conf:",conf) #配置文件 9 # print("dj conf:",conf.settings)#配置文件.设置 10 # ————————04PerfectCRM实现King_admin注册功能———————— 11 12 # ————————04PerfectCRM实现King_admin注册功能———————— 13 from king_admin import app_config #自动调用 动态加载类和函数 14 # ————————04PerfectCRM实现King_admin注册功能———————— 15 16 # ————————04PerfectCRM实现King_admin注册功能———————— 17 # from king_admin.base_admin import registered_sites # registered_sites={} 18 from king_admin import base_admin 19 # ————————04PerfectCRM实现King_admin注册功能———————— 20 21 # ————————11PerfectCRM实现King_admin基本分页———————— 22 from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger # 分页功能 23 # ————————11PerfectCRM实现King_admin基本分页———————— 24 25 def app_index(request): 26 # ————————04PerfectCRM实现King_admin注册功能———————— 27 # for app in conf.settings.INSTALLED_APPS: 28 # print(app)#循环打印 配置文件.设置.安装应用程序#.Perfectcustomersettings里的INSTALLED_APPS列表 29 # ————————04PerfectCRM实现King_admin注册功能———————— 30 31 # ————————04PerfectCRM实现King_admin注册功能———————— 32 # return render(request, 'king_admin/app_index.html') 33 # print("registered_sites",registered_sites) 34 # return render(request, 'king_admin/app_index.html') 35 # ————————04PerfectCRM实现King_admin注册功能———————— 36 37 # ————————04PerfectCRM实现King_admin注册功能———————— 38 # print("registered_sites", base_admin.registered_sites) 39 # return render(request, 'king_admin/app_index.html') 40 # ————————04PerfectCRM实现King_admin注册功能———————— 41 42 # ————————05PerfectCRM实现King_admin注册功能获取内存———————— 43 print("registered_sites",base_admin.site.registered_sites) 44 return render(request, 'king_admin/app_index.html', {"site": base_admin.site}) 45 # ————————05PerfectCRM实现King_admin注册功能获取内存———————— 46 47 # ————————02PerfectCRM创建ADMIN页面———————— 48 49 50 # ————————13PerfectCRM实现King_admin分页页数———————— 51 #处理def table_data_list(request,app_name,model_name):里的内容, 52 def filter_querysets(request,queryset): 53 condtions = {} 54 for k,v in request.GET.items():#不需要空的,判断是否为空 55 56 # ————————17PerfectCRM实现King_admin单列排序———————— 57 # if k=="page":continue##kingadmin分页功能 58 59 # if k=="page":continue##kingadmin分页功能 #写法一 60 # elif k=="_o":continue##kingadmin排序功能 <a href="?_o={{ column }}">{{ column }}</a> 61 62 # if k in ("page","_o") :continue #kingadmin分页功能 #kingadmin排序功能 #写法二 63 64 if k == "page"or k == "_o": #保留的分页关键字 和 排序关键字 #写法三 65 continue #continue是结束单次循环 66 # ————————17PerfectCRM实现King_admin单列排序———————— 67 68 # ————————15PerfectCRM实现King_admin多条件过滤———————— 69 if v: 70 condtions[k] = v 71 # ————————15PerfectCRM实现King_admin多条件过滤———————— 72 query_res = queryset.filter(**condtions) 73 return query_res,condtions 74 # ————————13PerfectCRM实现King_admin分页页数———————— 75 76 # ————————08PerfectCRM实现King_admin显示注册表的字段表头———————— 77 def table_data_list(request,app_name,model_name): 78 #通过2个参数到base_admin里获取class AdminRegisterException(Exception): 的对象 79 admin_obj = base_admin.site.registered_sites[app_name][model_name] #base_admin 80 81 # ————————09PerfectCRM实现King_admin显示注册表的内容———————— 82 admin_obj.querysets = admin_obj.model.objects.all()#取数据 传到 前端 83 # ————————09PerfectCRM实现King_admin显示注册表的内容———————— 84 85 # ————————11PerfectCRM实现King_admin分页显示条数———————— 86 # from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger # 分页功能#放在顶上导入 87 obj_list = admin_obj.model.objects.all()#取数据 传到 前端 #base_admin #获取传过来的所有对象 88 89 # ————————13PerfectCRM实现King_admin分页页数———————— 90 queryset, condtions = filter_querysets(request, obj_list) #base_admin # 调用条件过滤 91 # ————————13PerfectCRM实现King_admin分页页数———————— 92 93 # ————————17PerfectCRM实现King_admin单列排序———————— 94 sorted_queryset = get_orderby(request, queryset) #过滤后的结果 95 # ————————15PerfectCRM实现King_admin多条件过滤———————— 96 # paginator = Paginator(obj_list,admin_obj.list_per_page) #kingadmin里class CustomerAdmin(BaseAdmin): 97 # paginator = Paginator(queryset, admin_obj.list_per_page) 98 # ————————15PerfectCRM实现King_admin多条件过滤———————— 99 paginator = Paginator(sorted_queryset, admin_obj.list_per_page) 100 # ————————17PerfectCRM实现King_admin单列排序———————— 101 102 103 page = request.GET.get('page') 104 try: 105 objs = paginator.page(page) # 当前的页面的数据 106 except PageNotAnInteger: 107 # 如果页面不是一个整数,交付第一页。 108 objs = paginator.page(1) 109 except EmptyPage: 110 # 如果页面的范围(例如9999),交付最后一页的搜索结果。 111 objs = paginator.page(paginator.num_pages) 112 admin_obj.querysets = objs # base_admin 113 114 # ————————13PerfectCRM实现King_admin分页页数———————— 115 admin_obj.filter_condtions = condtions # base_admin 116 # ————————13PerfectCRM实现King_admin分页页数———————— 117 118 # ————————11PerfectCRM实现King_admin分页显示条数———————— 119 120 return render(request,"king_admin/table_data_list.html",locals()) 121 # ————————08PerfectCRM实现King_admin显示注册表的字段表头———————— 122 123 124 125 # ————————17PerfectCRM实现King_admin单列排序———————— 126 def get_orderby(request,queryset): 127 # order_by_key = request.GET.get("_o") #获取URL里有没有("_o") <a href="?_o={{ column }}">{{ column }}</a> 128 # #页面刚开始没有这个值 129 # if order_by_key != None: #有("_o")这个值 就进行排序 130 # query_res = queryset.order_by(order_by_key) 131 # else: #没有就不排序,直接返回 132 # query_res = queryset 133 # return query_res #排序时会错 134 135 orderby_key = request.GET.get("_o") 136 if orderby_key: 137 return queryset.order_by(orderby_key) 138 return queryset 139 140 #在table_data_list添加 141 # def table_data_list(request,app_name,model_name): #详细列表 142 # sorted_queryset = get_orderby(request, queryset) 143 #在filter_querysets添加 144 #if k == "page"or k == "_o": #保留的分页关键字 和 排序关键字 145 # ————————17PerfectCRM实现King_admin单列排序————————