zoukankan      html  css  js  c++  java
  • Django项目:CRM(客户关系管理系统)--31--23PerfectCRM实现King_admin数据删除

    登陆密码设置参考

    http://www.cnblogs.com/ujq3/p/8553784.html

     1 # king_urls.py
     2 # ————————02PerfectCRM创建ADMIN页面————————
     3 from django.conf.urls import url
     4 from king_admin import views
     5 
     6 urlpatterns = [
     7     url(r'^$', views.app_index),#主页
     8 
     9     # ————————21PerfectCRM实现King_admin查看页面美化————————
    10     url(r'^(w+)/$', views.table_index, name='table_index'),  # 单个具体app页面
    11     # ————————21PerfectCRM实现King_admin查看页面美化————————
    12 
    13     # ————————08PerfectCRM实现King_admin显示注册表的字段表头————————
    14     url(r'^(w+)/(w+)/$', views.table_data_list,name='table_data_list'),#详细内容
    15     # ————————08PerfectCRM实现King_admin显示注册表的字段表头————————
    16 
    17     # ————————19PerfectCRM实现King_admin数据修改————————
    18     url(r'^(w+)/(w+)/(d+)/change/$', views.table_change,name='table_change'),#修改信息
    19     # ————————19PerfectCRM实现King_admin数据修改————————
    20 
    21     # ————————22PerfectCRM实现King_admin数据添加————————
    22     url(r'^(w+)/(w+)/add/$', views.table_add,name='table_add'),  #添加信息
    23     # ————————22PerfectCRM实现King_admin数据添加————————
    24 
    25     # ————————23PerfectCRM实现King_admin数据删除————————
    26     url(r'^(w+)/(w+)/(d+)/delete/$', views.table_delete, name="table_delete"),  # 删除信息
    27     # ————————23PerfectCRM实现King_admin数据删除————————
    28 ]
    29 # ————————02PerfectCRM创建ADMIN页面————————
    # king_urls.py

      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         # ————————18PerfectCRM实现King_admin搜索关键字————————
     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         if k in ("page", "_o", "_q"): continue  # kingadmin分页,排序,搜索#判断标签是否存在 自定义的名称
     68         # ————————18PerfectCRM实现King_admin搜索关键字————————
     69 
     70 
     71         # ————————15PerfectCRM实现King_admin多条件过滤————————
     72         if v:
     73             condtions[k] = v
     74         # ————————15PerfectCRM实现King_admin多条件过滤————————
     75     query_res = queryset.filter(**condtions)
     76     return query_res,condtions
     77 # ————————13PerfectCRM实现King_admin分页页数————————
     78 
     79 # ————————08PerfectCRM实现King_admin显示注册表的字段表头————————
     80 def table_data_list(request,app_name,model_name):
     81     #通过2个参数到base_admin里获取class AdminRegisterException(Exception): 的对象
     82     admin_obj = base_admin.site.registered_sites[app_name][model_name]  #base_admin
     83 
     84     # ————————09PerfectCRM实现King_admin显示注册表的内容————————
     85     admin_obj.querysets =  admin_obj.model.objects.all()#取数据 传到 前端
     86     # ————————09PerfectCRM实现King_admin显示注册表的内容————————
     87 
     88     # ————————11PerfectCRM实现King_admin分页显示条数————————
     89     # from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger  # 分页功能#放在顶上导入
     90     obj_list =  admin_obj.model.objects.all()#取数据 传到 前端  #base_admin  #获取传过来的所有对象
     91 
     92     # ————————13PerfectCRM实现King_admin分页页数————————
     93     queryset, condtions = filter_querysets(request, obj_list)  #base_admin   # 调用条件过滤
     94     # ————————13PerfectCRM实现King_admin分页页数————————
     95 
     96     # ————————18PerfectCRM实现King_admin搜索关键字————————
     97     queryset = get_queryset_search_result(request,queryset,admin_obj)##搜索后
     98     # ————————18PerfectCRM实现King_admin搜索关键字————————
     99 
    100     # ————————17PerfectCRM实现King_admin单列排序————————
    101     sorted_queryset = get_orderby(request, queryset) #过滤后的结果
    102     # ————————15PerfectCRM实现King_admin多条件过滤————————
    103     # paginator = Paginator(obj_list,admin_obj.list_per_page)  #kingadmin里class CustomerAdmin(BaseAdmin):
    104     # paginator = Paginator(queryset, admin_obj.list_per_page)
    105     # ————————15PerfectCRM实现King_admin多条件过滤————————
    106     paginator = Paginator(sorted_queryset, admin_obj.list_per_page)
    107     # ————————17PerfectCRM实现King_admin单列排序————————
    108 
    109 
    110     page = request.GET.get('page')
    111     try:
    112         objs = paginator.page(page)  # 当前的页面的数据
    113     except PageNotAnInteger:
    114         # 如果页面不是一个整数,交付第一页。
    115         objs = paginator.page(1)
    116     except EmptyPage:
    117         # 如果页面的范围(例如9999),交付最后一页的搜索结果。
    118         objs = paginator.page(paginator.num_pages)
    119     admin_obj.querysets = objs  # base_admin
    120 
    121     # ————————13PerfectCRM实现King_admin分页页数————————
    122     admin_obj.filter_condtions = condtions  # base_admin
    123     # ————————13PerfectCRM实现King_admin分页页数————————
    124 
    125     # ————————11PerfectCRM实现King_admin分页显示条数————————
    126 
    127     return render(request,"king_admin/table_data_list.html",locals())
    128 # ————————08PerfectCRM实现King_admin显示注册表的字段表头————————
    129 
    130 
    131 
    132 # ————————17PerfectCRM实现King_admin单列排序————————
    133 def get_orderby(request,queryset):
    134     # order_by_key = request.GET.get("_o")   #获取URL里有没有("_o") <a href="?_o={{ column }}">{{ column }}</a>
    135     # #页面刚开始没有这个值
    136     # if order_by_key != None:  #有("_o")这个值 就进行排序
    137     #     query_res = queryset.order_by(order_by_key)
    138     # else: #没有就不排序,直接返回
    139     #     query_res = queryset
    140     # return query_res     #排序时会错
    141 
    142     orderby_key = request.GET.get("_o")
    143     if orderby_key:
    144         return  queryset.order_by(orderby_key)
    145     return  queryset
    146 
    147 #在table_data_list添加
    148 # def table_data_list(request,app_name,model_name): #详细列表
    149 # sorted_queryset = get_orderby(request, queryset)
    150 #在filter_querysets添加
    151 #if k == "page"or k == "_o": #保留的分页关键字 和  排序关键字
    152 # ————————17PerfectCRM实现King_admin单列排序————————
    153 
    154 # ————————18PerfectCRM实现King_admin搜索关键字————————
    155 from django.db.models import Q
    156 def get_queryset_search_result(request,queryset,admin_obj):
    157     search_key = request.GET.get("_q", "")#取定义名,默认为空
    158     q_obj = Q()#多条件搜索 #from django.db.models import Q
    159     q_obj.connector = "OR"  # or/或 条件
    160     for column in admin_obj.search_fields: #搜索目标crm/kingadmin里class CustomerAdmin(BaseAdmin):search_fields = ('name','qq',)
    161         q_obj.children.append(("%s__contains" % column, search_key)) #运态添加多个条件
    162     res = queryset.filter(q_obj) #对数据库进行条件搜索
    163     return res   #返回结果
    164 #在table_data_list添加
    165 #def table_data_list(request,app_name,model_name): #详细列表
    166 #      queryset = get_queryset_search_result(request,queryset,admin_obj)
    167 # ————————18PerfectCRM实现King_admin搜索关键字————————
    168 
    169 # ————————19PerfectCRM实现King_admin数据修改————————
    170 from  king_admin import forms
    171 #修改内容
    172 # def table_change(request,app_name,model_name):
    173 #     obj_form = forms.CustomerModelForm()  #创建一个空表单
    174 #     return render(request,"kingadmin/table_change.html",locals())
    175 
    176 def table_change(request,app_name,model_name,obj_id):
    177     admin_obj = base_admin.site.registered_sites[app_name][model_name]   #获取表对象
    178                 #kingadmin/forms.py里def CreateModelForm(request,admin_obj):
    179     model_form = forms.CreateModelForm(request,admin_obj=admin_obj)  ##modelform 生成表单 加验证
    180     # obj_form = model_form()  # 表单
    181     obj = admin_obj.model.objects.get(id=obj_id)#根据ID获取数据记录
    182 
    183     # ————————20PerfectCRM实现King_admin数据修改美化————————
    184     # #面向对象最重要的概念就是类(Class)和实例(Instance),必须牢记类是抽象的模板,比如Student类,而实例是根据类创建出来的一个个具体的“对象”,每个对象都拥有相同的方法,但各自的数据可能不同。
    185     # obj_form = model_form(instance=obj)  # 数据传入表单
    186 
    187     if request.method == "GET":
    188         obj_form = model_form(instance=obj)
    189     elif request.method == "POST":
    190         obj_form = model_form(instance=obj,data=request.POST)
    191         if obj_form.is_valid():
    192             obj_form.save()
    193     # ————————20PerfectCRM实现King_admin数据修改美化————————
    194 
    195     return render(request,"king_admin/table_change.html",locals())
    196 # ————————19PerfectCRM实现King_admin数据修改————————
    197 
    198 # ————————21PerfectCRM实现King_admin查看页面美化————————
    199 #单个具体app页面
    200 def table_index(request,app_name):
    201     bases=base_admin.site.registered_sites[app_name]#取出对应app对象
    202     return render(request, 'king_admin/table_index.html', {"site":bases,'app_name':app_name})
    203 # ————————21PerfectCRM实现King_admin查看页面美化————————
    204 
    205 
    206 
    207 
    208 
    209 # ————————22PerfectCRM实现King_admin数据添加————————
    210 from django.shortcuts import redirect  # kingadmin添加内容
    211 def table_add(request,app_name,model_name):
    212     admin_obj = base_admin.site.registered_sites[app_name][model_name]  #获取表对象
    213     model_form = forms.CreateModelForm(request,admin_obj=admin_obj) ##modelform 生成表单 加验证
    214 
    215     if request.method == "GET":
    216         obj_form = model_form()
    217 
    218     elif request.method == "POST":
    219         obj_form = model_form(data=request.POST)  #创建数据
    220         if obj_form.is_valid():
    221             obj_form.save()
    222         if not obj_form.errors:   #没有错误返回原来的页面
    223             #from django.shortcuts import redirect
    224             return  redirect("/king_admin/%s/%s/" % (app_name,model_name))
    225     return render(request, "king_admin/table_add.html", locals())
    226 
    227 # ————————22PerfectCRM实现King_admin数据添加————————
    228 
    229 
    230 # ————————23PerfectCRM实现King_admin数据删除————————
    231 def table_delete(request,app_name,model_name,obj_id):
    232     admin_obj = base_admin.site.registered_sites[app_name][model_name]#表类
    233     objs=admin_obj.model.objects.filter(id=obj_id)#类的对象
    234     if request.method=='POST':
    235         objs.delete()#删除
    236         return redirect("/king_admin/%s/%s/" % (app_name,model_name))#转到列表页面
    237     return render(request, "king_admin/table_delete.html", locals())#locals 返回一个包含当前范围的局部变量字典。
    238 # ————————23PerfectCRM实现King_admin数据删除————————
    #views

     1 {% extends 'king_admin/table_index.html' %}
     2 {% load kingadmin_tags %}
     3 
     4 {% block right-container-content %}
     5     <h3>你确定吗?</h3>
     6     <h5>你确认想要删除 <span style="color: red">{{ model_name }}:{{ objs }}</span>? 下列所有相关的项目都将被删除:</h5>
     7     <h3>对象</h3>
     8     {% display_all_related_obj objs %}
     9 
    10 
    11     <form action="" method="post">{% csrf_token %}
    12         <input type="submit" class="btn btn-danger" value="确定删除">
    13         <a href="{% url 'table_data_list' app_name model_name %}" class="btn btn-info">取消,返回</a>
    14     </form>
    15 {% endblock %}
    {#table_delete.html#}

     1 {#table_change.html#}
     2 {## ————————19PerfectCRM实现King_admin数据修改————————#}
     3 {#{% extends "king_master/king_index.html" %}#}
     4 {##}
     5 {#{% load kingadmin_tags %}#}
     6 {#{% block right-container-content %}#}
     7 {##}
     8 {#      {{ obj_form }}#}
     9 {##}
    10 {#{% endblock %}#}
    11 {## ————————19PerfectCRM实现King_admin数据修改————————#}
    12 
    13 {## ————————20PerfectCRM实现King_admin数据修改美化————————#}
    14 {% extends 'king_master/king_index.html' %}   {#继承模板#}
    15 {% load kingadmin_tags %} {#通过自己定义标签获取中文,Django中利用filter与simple_tag为前端自定义函数的实现方法#}
    16 
    17 {% block right-container-content %}
    18     <div class="row" style="margin-bottom: 20px" >
    19         <ol class="breadcrumb">
    20           <li><a href="/king_admin/">主页</a></li>
    21           <li><a href="/king_admin/{% get_app_name admin_obj.model %}/">{% get_app_name admin_obj.model %}</a></li>
    22           <li><a href="/king_admin/{% get_app_name admin_obj.model %}/{% get_model_name admin_obj.model %}/">
    23                 {% get_model_verbose_name admin_obj.model %} </a></li>
    24             {% if not admin_obj.is_add_form %} {#  新建时 ForeignKey不能实例化 #}
    25                <li class="active">{{ obj_form.instance }}</li>  {#  修改时 实例化 #}
    26             {% endif %}
    27         </ol>
    28         <h4>修改:{% get_model_verbose_name admin_obj.model  %}</h4>
    29     </div>
    30 
    31    <div class="row">
    32         {{ obj_form.errors  }}
    33         <form class="form-horizontal" method="post" onsubmit="return BeforeFormSubmit(this);">{% csrf_token %}
    34             {% for field in obj_form %}
    35                   <div class="form-group">
    36                     <label  class="col-sm-2 " style="font-weight: normal"> {#字体#}
    37                         {% if field.field.required %}   {#required判断是不是必须填写#}
    38                             <b>{{ field.label }}</b>
    39                         {% else %}
    40                             {{ field.label }}
    41                         {% endif %}
    42 
    43                     </label>
    44                     <div class="col-sm-10">
    45                         <span style="color: red;">{{ field.errors }}</span>
    46                             {{ field }}
    47                     </div>
    48                   </div>
    49             {% endfor %}
    50 
    51             {## ————————23PerfectCRM实现King_admin数据删除————————#}
    52             <a class="btn btn-danger" href="{% url 'table_delete' app_name model_name obj_form.instance.id %}">删除</a>
    53            {## ————————23PerfectCRM实现King_admin数据删除————————#}
    54 
    55             <input type="submit" value="保存" class="pull-right btn btn-info" >   {#放右边#}
    56         </form>
    57    </div>
    58 {% endblock %}
    59 {## ————————20PerfectCRM实现King_admin数据修改美化————————#}
    {#table_change.html#}

      1 #kingadmin_tags.py
      2 
      3 # ————————06PerfectCRM实现King_admin注册功能获取内存优化处理————————
      4 
      5 # # 因为前端禁止使用下划线开头(_meta.verbose_name ),所以通过后端处理后返回前端。
      6 # from django import template #模板
      7 # register = template.Library() #模板库
      8 #
      9 # @register.simple_tag #Django中利用filter与simple_tag为前端自定义函数的实现方法
     10 # def get_app_name(model_obj):
     11 #
     12 #     # ————————06PerfectCRM实现King_admin注册功能获取内存优化处理————————
     13 #     # return model_obj._meta.verbose_name_plural
     14 #     '''
     15 #      #判断 数据库 里如果有  verbose_name  或者  verbose_name_plural 就 调用  如果都没有 就使用默认的(英文)
     16 #         class Meta:
     17 #         verbose_name = "04客户信息表"           #在 Django  Admin 里 表名显示中文 但是会加s
     18 #         verbose_name_plural = "04客户信息表"    #在 Django  Admin 里 表名显示中文 不会加s
     19 #     '''
     20 #     model_name = model_obj._meta.verbose_name_plural if model_obj._meta.verbose_name else model_obj._meta.verbose_name_plural
     21 #     if not model_name:
     22 #         model_name = model_obj._meta.model_name
     23 #
     24 #     return model_name
     25     # ————————06PerfectCRM实现King_admin注册功能获取内存优化处理————————
     26 
     27 # ————————06PerfectCRM实现King_admin注册功能获取内存优化处理————————
     28 
     29 # ————————07PerfectCRM实现King_admin显示注册的表————————
     30 #因为前端禁止使用下划线开头(_meta.verbose_name ),所以通过后端处理后返回前端。
     31 from django import template #模板
     32 register = template.Library() #模板库
     33 
     34 
     35 
     36 @register.simple_tag #Django中利用filter与simple_tag为前端自定义函数的实现方法
     37 def get_model_verbose_name(model_obj):
     38     '''
     39      #判断 数据库 里如果有  verbose_name  或者  verbose_name_plural 就 调用  如果都没有 就使用默认的(英文)
     40         class Meta:
     41         verbose_name = "04客户信息表"           #在 Django  Admin 里 表名显示中文 但是会加s
     42         verbose_name_plural = "04客户信息表"    #在 Django  Admin 里 表名显示中文 不会加s
     43     '''
     44     model_name = model_obj._meta.verbose_name_plural if model_obj._meta.verbose_name else model_obj._meta.verbose_name_plural
     45     if not model_name:
     46         model_name = model_obj._meta.model_name
     47     return model_name
     48 
     49 @register.simple_tag
     50 def get_model_name(model_obj):
     51     return model_obj._meta.model_name
     52 @register.simple_tag
     53 def get_app_name(model_obj):
     54     return model_obj._meta.app_label
     55 # ————————07PerfectCRM实现King_admin显示注册的表————————
     56 
     57 
     58 # ————————09PerfectCRM实现King_admin显示注册表的内容————————
     59 from django.utils.safestring import mark_safe #使用mark_safe函数标记后,django将不再对该函数的内容进行转义
     60 @register.simple_tag
     61 def build_table_row(admin_obj,obj):#通过kingadmin_tags在后台处理 再传到前端
     62     row_ele = "" #为了生成一整行返回前端
     63     if admin_obj.list_display:#如果不为空,有在crm/kingadmin.py注册site.register(models.Customer,CustomerAdmin)
     64 
     65         # ————————19PerfectCRM实现King_admin数据修改————————
     66         #循环所有 要显示 的字符串 进行反射 展示 字段
     67         # for column in admin_obj.list_display: #循环base_admin里class BaseAdmin下list_display = ()
     68         for index, column in enumerate(admin_obj.list_display):  # 转为列表取 下标 , 字段名
     69         # ————————19PerfectCRM实现King_admin数据修改————————
     70 
     71             column_obj = obj._meta.get_field(column)#遍历获取  传进的参数对象
     72             if column_obj.choices:#判断如果字段有choices属性
     73                 #获取choices的字符串(外健)
     74                 get_column_data = getattr(obj,"get_%s_display" % column) #反射,传进的参数对象,拼接字段
     75                 column_data = get_column_data()#函数,拿到数据
     76             else:
     77                 column_data = getattr(obj, column)#反射,
     78             # ————————10PerfectCRM实现King_admin日期优化————————
     79             if type(column_data).__name__ == 'datetime':
     80                 column_data = column_data.strftime('%Y-%m-%d %H-%M-%S')
     81             # ————————10PerfectCRM实现King_admin日期优化————————
     82 
     83             # ————————19PerfectCRM实现King_admin数据修改————————
     84 
     85             if index == 0: #首列
     86                 # 生成一个链接 跳转到编辑页面        #Format参数是一个格式字符串(%s升级版)
     87                 td_ele = '''<td><a href="/king_admin/{app_name}/{model_name}/{obj_id}/change/">{column_data}</a> </td>'''
     88                             .format(app_name=admin_obj.model._meta.app_label,
     89                                     model_name=admin_obj.model._meta.model_name,
     90                                     obj_id=obj.id,
     91                                     column_data=column_data)
     92             else:
     93                 td_ele = '''<td>%s</td>''' % column_data
     94             # td_ele = '''<td>%s</td>''' % column_data  #把反射来的值 拼接字符串 生成<td>
     95             # ————————19PerfectCRM实现King_admin数据修改————————
     96             row_ele += td_ele    #把 <td>  拼接到上面到空字符串
     97     else:
     98         row_ele +="<td>%s</td>" %obj  #把<td>拼接到上面到空字符串,crm/models.py里 def __str__(self):的返回值
     99     return mark_safe(row_ele) #使用mark_safe函数标记后,django将不再对该函数的内容进行转义
    100 # ————————09PerfectCRM实现King_admin显示注册表的内容————————
    101 
    102 
    103 # ————————13PerfectCRM实现King_admin分页页数————————
    104 #分页功能kingadmin/templates/kingadmin/table_data_list.html里 <a href="?page={{ page }}{%  generate_filter_url admin_obj %}">{{ page }}
    105 @register.simple_tag
    106 def generate_filter_url(admin_obj): #拼接URL
    107     url = ''
    108     for k,v in admin_obj.filter_condtions.items():
    109         url += "&%s=%s" %(k,v )
    110     return url
    111 # ————————13PerfectCRM实现King_admin分页页数————————
    112 
    113 # ————————14PerfectCRM实现King_admin分页的省略显示————————
    114 #分页的省略显示
    115 @register.simple_tag
    116 def pag_omit(request,admin_obj):#传入当前页面值
    117     rest=''#大字符串
    118     # ————————18PerfectCRM实现King_admin搜索关键字————————
    119     search_key = get_search_key(request)  # 搜索
    120     # ————————18PerfectCRM实现King_admin搜索关键字————————
    121     # ————————17PerfectCRM实现King_admin单列排序————————
    122     order_by_url = generate_order_by_url(request)  # 排序
    123     # ————————17PerfectCRM实现King_admin单列排序————————
    124     # ————————15PerfectCRM实现King_admin多条件过滤————————
    125     filters = generate_filter_url(admin_obj)  # 分页
    126     # ————————15PerfectCRM实现King_admin多条件过滤————————
    127     add_tags=False#标志位
    128     for pages in admin_obj.querysets.paginator.page_range:
    129         #   前两页    或   后  两页                                       或    当前页的前后页
    130         if pages < 3 or pages>admin_obj.querysets.paginator.num_pages -2 or abs(admin_obj.querysets.number -pages) <=2:
    131             #样式
    132             add_tags=False
    133             ele_class=''  #颜色
    134             if pages == admin_obj.querysets.number: #--如果是当前页码,颜色加深 不进链接跳转--
    135                 ele_class="active"    #颜色加深
    136             # ————————18PerfectCRM实现King_admin搜索关键字————————
    137             # ————————17PerfectCRM实现King_admin单列排序————————
    138             # ————————15PerfectCRM实现King_admin多条件过滤————————
    139             # rest+='''<li class="%s"><a href="?page=%s">%s</a></li>'''%(ele_class,pages,pages)  #--拼接URL--
    140             # rest+='''<li class="%s"><a href="?page=%s%s">%s</a></li>'''%(ele_class,pages,filters,pages)  #--拼接URL--
    141             # ————————15PerfectCRM实现King_admin多条件过滤————————
    142             # rest+='''<li class="%s"><a href="?page=%s%s%s">%s<span class="sr-only">(current)</span></a></li>'''
    143             #         %(ele_class,pages,order_by_url,filters,pages)
    144             # ————————17PerfectCRM实现King_admin单列排序————————
    145             rest+='''<li class="%s"><a href="?page=%s%s%s&_q=%s">%s<span class="sr-only">(current)</span></a></li>'''
    146                     %(ele_class,pages,order_by_url,filters,search_key,pages)
    147             # ————————18PerfectCRM实现King_admin搜索关键字————————
    148         else:#其他的用省略号表示
    149             if add_tags==False:#如果不是标志位的页面
    150                 rest+='<li><a>...</a></li>'
    151                 add_tags=True#标志位为真
    152     return mark_safe(rest)  #使用mark_safe函数标记后,django将不再对该函数的内容进行转义
    153 
    154 # ————————14PerfectCRM实现King_admin分页的省略显示————————
    155 
    156 
    157 
    158 # # ————————15PerfectCRM实现King_admin多条件过滤————————
    159 # #多条件过滤  table_data_list.html 传递参数
    160 # @register.simple_tag
    161 # def get_filter_field (filter_column,admin_obj):
    162 #     print("admin obj",admin_obj.model ,filter_column)
    163 #     field_obj = admin_obj.model._meta.get_field(filter_column)#调用内置方法
    164 #     select_ele = """<select name="%s"> """ %filter_column #拼接成下拉框返回
    165 #     for choice in field_obj.get_choices():#循环获取crm/models里class Customer(models.Model):下source_choices = ((0,'转介绍'),
    166 #         selected_condtion = admin_obj.filter_condtions.get(filter_column)
    167 #         if selected_condtion != None: #if None, 没有过滤这个条件
    168 #             print("heoe....",filter_column,selected_condtion,type(selected_condtion))#类型是 整数
    169 #             if selected_condtion == str(choice[0]): #就是选择的这个条件,整数转字符串
    170 #                 selected = "selected"
    171 #             else:
    172 #                 selected = ""
    173 #         else:
    174 #             selected = ""
    175 #
    176 # #在前端把几个条件提交到后台,后台拿着条件变成一个字典,然后进行过滤,把数据返回前端,并且把条件作为字典返回后端,因为要在前端显示已经过滤的条件。
    177 #         option_ele = """<option value="%s" %s>%s</option> """ % (choice[0],selected,choice[1])
    178 #         select_ele +=option_ele
    179 #     select_ele += "</select>"
    180 #     return mark_safe(select_ele)
    181 # # ————————15PerfectCRM实现King_admin多条件过滤————————
    182 
    183 # # ————————16PerfectCRM实现King_admin日期过滤————————
    184 from django.utils.timezone import datetime,timedelta
    185 @register.simple_tag
    186 def get_filter_field (filter_column,admin_obj):
    187     select_ele = """<select name='{filter_column}'><option  value="">---------</option>""" #标签 字符串 #拼接成下拉框返回
    188     field_obj = admin_obj.model._meta.get_field(filter_column)#调用内置方法
    189     selected = ''
    190     if field_obj.choices:
    191         for choice_item in field_obj.choices:
    192             if admin_obj.filter_condtions.get(filter_column) == str(choice_item[0]):
    193                 selected = "selected"
    194             select_ele  +=  """<option value="%s" %s>%s</option> """ % (choice_item[0], selected, choice_item[1])
    195             selected = ""
    196 
    197     if type(field_obj).__name__ in "ForeignKey":
    198         for choice_item in field_obj.get_choices()[1:]:
    199             if admin_obj.filter_condtions.get(filter_column)== str(choice_item[0]):  # 就是选择的这个条件,整数转字符串
    200                 selected = "selected"
    201             select_ele += """<option value="%s" %s>%s</option> """ % (choice_item[0], selected, choice_item[1])
    202             selected=''
    203 
    204     if type(field_obj).__name__ in ['DateTimeField', 'DateField']:  # 如果是时间格式
    205         date_els = []  # 日期条件项
    206         today_ele = datetime.now().date()  # 今天日期
    207         date_els.append(['今天', today_ele])  # 今天
    208         date_els.append(['昨天', today_ele - timedelta(days=1)])  # 昨天
    209         date_els.append(['近7天', today_ele - timedelta(days=7)])  # 一周
    210         date_els.append(['近30天', today_ele - timedelta(days=30)])  # 三十
    211         date_els.append(['本月', today_ele.replace(day=1)])  # 本月
    212         date_els.append(['近90天', today_ele - timedelta(days=90)])  # 90天
    213         date_els.append(['近365天', today_ele - timedelta(days=365)])  # 365天
    214         date_els.append(['本年', today_ele.replace(month=1, day=1)])  ##今年
    215 
    216         for choice_item in date_els:
    217             if admin_obj.filter_condtions.get("%s__gte" %filter_column)==str(choice_item[1]):
    218                 selected = 'selected'
    219             select_ele += """<option value="%s" %s>%s</option> """ % (choice_item[1], selected, choice_item[0])
    220             selected = ''
    221         filter_column_name = "%s__gte" %filter_column
    222     else:
    223         filter_column_name = filter_column
    224 
    225     select_ele += "</select>"
    226     select_ele=select_ele.format(filter_column=filter_column_name)#格式化时间的判断条件
    227     return mark_safe(select_ele)
    228 # ————————16PerfectCRM实现King_admin日期过滤————————
    229 
    230 # ————————17PerfectCRM实现King_admin单列排序————————
    231 # kingadmin排序功能
    232 @register.simple_tag
    233 def  get_orderby_key(request,column):
    234     current_order_by_key = request.GET.get("_o")
    235     # ————————18PerfectCRM实现King_admin搜索关键字————————
    236     search_key = request.GET.get("_q")
    237     if search_key != None:
    238         if current_order_by_key != None: #如果不为空  #肯定有某列被排序了
    239             if current_order_by_key ==  column: # 判断是否相等 #当前这列正在被排序
    240                 if column.startswith("-"): #startsWith是String类中的一个方法,用来检测某字符串是否以另一个字符串开始,返回值为boolean类型
    241                     return column.strip("-") #strip去掉  文本中句子开头与结尾的符号的
    242                 else:
    243                     return "-%s&_q=%s" % (column, search_key)
    244         return "%s&_q=%s" % (column, search_key)
    245     else:
    246     # ————————18PerfectCRM实现King_admin搜索关键字————————
    247         if current_order_by_key != None: #如果不为空  #肯定有某列被排序了
    248             if current_order_by_key ==  column: # 判断是否相等 #当前这列正在被排序
    249                 if column.startswith("-"): #startsWith是String类中的一个方法,用来检测某字符串是否以另一个字符串开始,返回值为boolean类型
    250                     return column.strip("-") #strip去掉  文本中句子开头与结尾的符号的
    251                 else:
    252                     return "-%s"%column
    253         #     else:
    254         #         return column
    255         # else:
    256         #     return column
    257         return column   #同上4句
    258 # kingadmin排序功能
    259 
    260 # kingadmin排序功能  显示排序图标
    261 # @register.simple_tag
    262 # def display_order_by_icon(request, column):
    263 #     current_order_by_key = request.GET.get("_o")
    264 #     if current_order_by_key != None: #肯定有某列被排序了
    265 #         if current_order_by_key.strip("-") == column: ## 当前这列正在被排序
    266 #             if current_order_by_key.startswith("-"):
    267 #                 icon = "fa-arrow-up"
    268 #             else:
    269 #                 icon = "fa-arrow-down"
    270 #             ele = """<i class="fa %s" aria-hidden="true"></i>""" % icon
    271 #             return mark_safe(ele)
    272 #     return ''
    273 # kingadmin排序功能  显示排序图标
    274 @register.simple_tag
    275 def display_order_by_icon(request, column):
    276     current_order_by_key = request.GET.get("_o")
    277     if current_order_by_key != None: #肯定有某列被排序了
    278         if current_order_by_key.strip("-") == column: # 当前这列正在被排序  #strip去掉  文本中句子开头与结尾的符号的
    279             if current_order_by_key.startswith("-"): #startsWith是String类中的一个方法,用来检测某字符串是否以另一个字符串开始,返回值为boolean类型
    280                 icon = ""
    281             else:
    282                 icon = ""
    283             ele = """<i style='color: red'>%s</i>""" % icon
    284             return mark_safe(ele)
    285     return '' #防止出现 None
    286 # kingadmin排序功能  显示排序图标
    287 
    288 # kingadmin排序功能  # 过滤后排序功能 #}
    289 @register.simple_tag
    290 def get_current_orderby_key(request): #注意生成的URL问题
    291     #获取当前正在排序的字段名   #<input type="hidden" name="_o" value="{% get_current_orderby_key request %}">
    292     current_order_by_key = request.GET.get("_o")
    293     return current_order_by_key or ''
    294 # kingadmin排序功能  # 过滤后排序功能 #}
    295 
    296 # kingadmin排序功能   # 过滤后排序功能 # 排序分页
    297 @register.simple_tag
    298 def generate_order_by_url (request):
    299     current_order_by_key = request.GET.get("_o")
    300     if current_order_by_key != None:  # 肯定有某列被排序了
    301         return "&_o=%s" % current_order_by_key
    302     return ''
    303 # kingadmin排序功能   # 过滤后排序功能 # 排序分页
    304 # ————————17PerfectCRM实现King_admin单列排序————————
    305 
    306 # ————————18PerfectCRM实现King_admin搜索关键字————————
    307 @register.simple_tag
    308 def get_search_key(request):   #  搜索框里保留搜索值
    309     search_key = request.GET.get("_q")
    310     return search_key or ''
    311 # ————————18PerfectCRM实现King_admin搜索关键字————————
    312 
    313 # ————————23PerfectCRM实现King_admin数据删除————————
    314 # <-------------------获取删除映射关系--------------------------------
    315 @register.simple_tag
    316 def display_all_related_obj(objs):
    317     # 取出对象及所有相关联的数据
    318     from django.db.models.query import QuerySet
    319     if type(objs) != QuerySet:
    320         objs = [objs, ]
    321     if objs:
    322         model_class = objs[0]._meta.model  # 取表对象
    323         model_name = objs[0]._meta.model_name  # 取表名
    324         return mark_safe(recursive_related_objs_lookup(objs))
    325 # <-----------------递归获取映射关系--------------------------------
    326 def recursive_related_objs_lookup(objs, name=None, conn_batch_size=0):
    327     name = set()
    328     print(name)
    329     print('传递过来的objs:', objs)
    330     # 开始标签的拼接
    331     ul_ele = "<ul style='color: blue'>"
    332     for obj in objs:
    333         li_ele = '''<li>{0}:{1}</li>'''.format(obj._meta.verbose_name, obj.__str__().strip("<>"))
    334         print('str:', obj.__str__(), '类型:', type(obj.__str__()))
    335         print('关联的表的自定表名:', li_ele)
    336         ul_ele += li_ele
    337         print('拼接li_ele:', ul_ele)
    338         # 映射关系处理
    339         # <---------------------------特殊关联处理-----------------------------------
    340         # 多对多关系
    341         for m2m_field in obj._meta.local_many_to_many:  # local_many_to_many返回列表,many_to_many返回元祖
    342             print('--开始循环反射-多对多-关系处理--')
    343             sub_ul_ele = "<ul style='color: red'>"
    344             m2m_field_obj = getattr(obj, m2m_field.name)  # 反射 如果有选项
    345             print('反射选项:', m2m_field_obj)
    346 
    347             for m2m_data in m2m_field_obj.select_related():
    348                 print('开始循环多对多标签拼接:', m2m_data)
    349 
    350                 sub_li_ele = '''<li>{0}:{1}</li>'''.format(m2m_field.verbose_name, m2m_data.__str__().strip("<>"))
    351                 sub_ul_ele += sub_li_ele
    352             sub_ul_ele += '</ul>'
    353             ul_ele += sub_ul_ele
    354             print('生成完整 多对多 标签..:', ul_ele)
    355         # <---------------------------外健关联处理------------------------------------
    356         for related_obj in obj._meta.related_objects:
    357             print('--开始-外健关联-处理--')
    358             if hasattr(obj, related_obj.get_accessor_name()):
    359                 print('--判断对象中是否包含反查属性--')
    360                 accessor_obj = getattr(obj, related_obj.get_accessor_name())
    361                 print('获取反查对应的对象: ')
    362                 if hasattr(accessor_obj, 'select_related'):
    363                     print('--判断有没有获取数据的方法或属性-- ')
    364                     target_object = accessor_obj.select_related()
    365                     print('获取数据的方法或属性: ', target_object)
    366 
    367                     if 'ManyToManyRel' in related_obj.__repr__():
    368                         print('--开始-外健关联-多对多-处理--.')
    369 
    370                         # 生成UL
    371                         sub_ul_ele = '<ul style="color: green">'
    372                         for data in target_object:
    373                             print('开始循环-外健关联-标签拼接...', data)
    374                             sub_li_ele = '''<li>{0}:{1}</li>'''.format(data._meta.verbose_name,
    375                                                                        data.__str__().strip("<>"))
    376                             sub_ul_ele += sub_li_ele
    377                         sub_ul_ele += '</ul>'
    378                         ul_ele += sub_ul_ele
    379                         print('-外健关联-生成完整标签:', ul_ele)
    380                     # <---------------递归处理-------------------
    381                     if len(target_object) != conn_batch_size:
    382                         print('--有下级对象存在,进行-递归-循环--')
    383                         names = target_object.__str__()
    384                         print(names, type(names))
    385                         if names == name:
    386                             print('--如果是自己关联自己,就不递归了--')
    387                             ul_ele += '</ul>'
    388                             return ul_ele
    389                         else:
    390                             print('--防止无限递归+1--')
    391                             conn_batch_size = conn_batch_size + 1
    392                             node = recursive_related_objs_lookup(target_object, name=names,
    393                                                                  conn_batch_size=conn_batch_size)
    394                             ul_ele += node
    395 
    396                     # <---------------由于使用递归,下面的标签样会发生重复,就不需要使用了--------------------
    397                 else:
    398                     print('外健关联 一对一:', accessor_obj)
    399                     target_object = accessor_obj
    400                     print("外健关联 一对一:", target_object, '属性:', type(target_object))
    401 
    402     ul_ele += '</ul>'
    403     return ul_ele
    404 
    405 # ————————23PerfectCRM实现King_admin数据删除————————
    #kingadmin_tags.py


     

    如果感觉本章博客对您有帮助,请尽情打赏吧!

  • 相关阅读:
    Perl 计算平均值
    Linux_SELinux使用
    Linux_SELinux使用
    【案例实战】餐饮企业分店财务数据分析系统解决方案:业务需求
    【案例实战】餐饮企业分店财务数据分析系统解决方案:系统功能开发
    【案例实战】餐饮企业分店财务数据分析系统解决方案:系统功能开发
    mysql binlog 分析
    perl 回调函数
    Linux_NFS/Samba服务器
    第六章 模块
  • 原文地址:https://www.cnblogs.com/ujq3/p/8675725.html
Copyright © 2011-2022 走看看