zoukankan      html  css  js  c++  java
  • Django项目:CRM(客户关系管理系统)--26--18PerfectCRM实现King_admin搜索关键字

    search_fields = ('name','qq',)



    登陆密码设置参考

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

    
    

    search_fields = ('name','qq',)
    
    

    
    
    search_fields = () #搜索(不能包含CharField)(注意加 逗号 , )

     1 #base_admin.py
     2 # ————————04PerfectCRM实现King_admin注册功能————————
     3 
     4 #Django admin 注册功能的形式
     5 # sites = {
     6 #     'crm':{
     7 #         'customers':CustomerAdmin,
     8 #         'customerfollowup':CustomerFollowUPAdmin,
     9 #     }
    10 # }
    11 
    12 class AdminRegisterException(Exception):  #自定义异常
    13     def __init__(self,msg):
    14         self.message = msg
    15 
    16 class BaseAdmin(object):#自定义方法
    17     list_display = ()  #显示的字段(不能包含ManyToManyField)
    18 
    19     # ————————11PerfectCRM实现King_admin分页显示条数————————
    20     list_per_page = 10  # 默认分页条数10
    21     # ————————11PerfectCRM实现King_admin分页显示条数————————
    22 
    23     # ————————15PerfectCRM实现King_admin多条件过滤————————
    24     list_filter = ()        # 过滤器(可以包含ManyToManyField) (注意加 逗号 , )
    25     # ————————15PerfectCRM实现King_admin多条件过滤————————
    26 
    27     # ————————18PerfectCRM实现King_admin搜索关键字————————
    28     search_fields = () #搜索(不能包含CharField)(注意加 逗号 , )
    29     # ————————18PerfectCRM实现King_admin搜索关键字————————
    30 
    31 # ————————05PerfectCRM实现King_admin注册功能获取内存————————
    32 class AdminSite(object):
    33     def __init__(self):
    34         self.registered_sites = {}   #传到views 里调用
    35     def register(self,model,admin_class=None): #默认值None 使用 BaseAdmin
    36         app_name = model._meta.app_label#用内置方法获取 APP名字 (crm)
    37         model_name = model._meta.model_name#用内置方法获取 表名  (Customer)
    38         if app_name not in self.registered_sites:
    39             self.registered_sites[app_name] = {} #创建  crm={}
    40         if model_name in self.registered_sites[app_name]:
    41             raise AdminRegisterException("app [%s] model [%s] has already registered!异常"
    42                                                  %(app_name,model_name))#自定义异常,
    43         if not  admin_class:
    44             admin_class = BaseAdmin  #默认值None 使用 BaseAdmin
    45         # self.registered_sites[app_name][model_name] = admin_class #注册APP
    46 # site = AdminSite()  # 实例化类  单例模式
    47 
    48 
    49         # ————————05PerfectCRM实现King_admin注册功能获取内存————————
    50         #registered_sites {'crm': {'customer': <class 'crm.kingadmin.CustomerAdmin'>, 'courserecord': <class 'kingadmin.base_admin.BaseAdmin'>}}
    51         #把类名放到class的对象里,然后通过class的对象传到前端
    52 #         admin_class.model = model
    53 #         self.registered_sites[app_name][model_name] = admin_class #注册APP
    54 #
    55 # site = AdminSite() #实例化类  单例模式
    56         # ————————05PerfectCRM实现King_admin注册功能获取内存————————
    57 
    58         # ————————06PerfectCRM实现King_admin注册功能获取内存优化处理————————
    59         #没有实例化会使用同一个内存地址
    60         admin_obj = admin_class()  #先实例化
    61         admin_obj.model = model    #参数赋值给实例
    62         self.registered_sites[app_name][model_name] = admin_obj#注册APP
    63         #实例化后,调用会使用不同的内存地址
    64 
    65 site = AdminSite() #实例化类  单例模式
    66         # ————————06PerfectCRM实现King_admin注册功能获取内存优化处理————————
    67         
    68 # registered_sites={}
    69 # def register(model,admin_class=None): #默认值None 使用 BaseAdmin
    70 #     app_name = model._meta.app_label#用内置方法获取 APP名字 (crm)
    71 #     model_name = model._meta.model_name#用内置方法获取 表名  (Customer)
    72 #     if app_name not in registered_sites:
    73 #         registered_sites[app_name] = {} #创建  crm={}
    74 #     if model_name in registered_sites[app_name]:
    75 #         raise AdminRegisterException("app [%s] model [%s] has already registered!异常"
    76 #                                              %(app_name,model_name))#自定义异常
    77 #     if not admin_class:
    78 #         admin_class = BaseAdmin  #默认值None 使用class BaseAdmin
    79 #     registered_sites[app_name][model_name] = admin_class #注册APP
    80 
    81 # ————————05PerfectCRM实现King_admin注册功能获取内存————————
    82 
    83 # ————————04PerfectCRM实现King_admin注册功能————————
    #base_admin.py

      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                 {## ————————18PerfectCRM实现King_admin搜索关键字————————#}
     40                 <hr>                                             {#过滤后搜索功能1#}  {## 搜索框里保留搜索值 #}
     41 {#                <input type="text" name="_q" value="{% get_search_key request %}">#}
     42 
     43                 <div class="row">
     44                     <div class="col-lg-2">
     45                         <input type="text" name="_q" value="{% get_search_key request %}">
     46                     </div>
     47                     <div class="col-lg-2">
     48                         <input type="submit" class="btn btn-success" value="搜索">
     49                     </div>
     50 
     51                     <div style='color: red'>  搜索条件包含:
     52                         {% for search_field in admin_obj.search_fields %}
     53                             {{ search_field }}
     54                             +
     55                         {% endfor %}
     56                     </div>
     57                 </div>
     58                 {## ————————18PerfectCRM实现King_admin搜索关键字————————#}
     59 
     60 
     61             </form>
     62         </div>
     63     {% endif %}
     64     {## ————————15PerfectCRM实现King_admin多条件过滤————————#}
     65 
     66     
     67 
     68 
     69     <table class="table table-hover">
     70           <thead>
     71             <tr>
     72 
     73              {## ————————17PerfectCRM实现King_admin单列排序————————#}
     74             {#循环调用kingadmin/base_admin里的class BaseAdmin下的list_display = () 方法#}
     75 {#                {% for column in admin_obj.list_display %}#}
     76 {#                    <th>{{ column }}</th>#}
     77 {#                {% endfor %}#}
     78 {#            #}
     79                 {% for column in admin_obj.list_display %}
     80 {#                    <th>{{ column }}</th>#}  {#过滤功能1#}
     81                     {#排序功能1#}
     82                     <th>
     83 {#                        <a href="?_o={{ column }}">{{ column }}</a>#}  {#http://127.0.0.1:8000/kingadmin/crm/customer/?_o=qq#}
     84                                        {## kingadmin排序功能#}
     85 {#                        <a href="?_o={% get_orderby_key request column %}">{{ column }}</a>#}
     86 
     87                                            {## kingadmin排序功能#}                       {# 过滤后排序功能 #}
     88                         <a href="?_o={% get_orderby_key request  column %}{%  generate_filter_url admin_obj %}">{{ column }}</a>
     89 
     90                                 {#显示排序图标#}
     91                         {% display_order_by_icon request column %}
     92 
     93                      </th>
     94                     {#排序功能1#}
     95                 {% endfor %}
     96                 {## ————————17PerfectCRM实现King_admin单列排序————————#}
     97 
     98 
     99             </tr>
    100           </thead>
    101 
    102         {## ————————09PerfectCRM实现King_admin显示注册表的内容————————#}
    103           <tbody>
    104             {#循环调用kingadmin/views 里的def table_data_list下的admin_obj.querysets #}
    105             {% for obj in admin_obj.querysets %}
    106                 <tr>
    107                     {#通过kingadmin_tags在后台处理 再传到前端 #}
    108                     {#调用kingadmin/templateags/kingadmin_tags 里的def build_table_row(admin_obj,obj):#}
    109                     {% build_table_row  admin_obj obj  %}
    110                 </tr>
    111             {% endfor %}
    112           </tbody>
    113         {## ————————09PerfectCRM实现King_admin显示注册表的内容————————#}
    114 
    115     </table>
    116 
    117     {## ————————12PerfectCRM实现King_admin分页上下页————————#}
    118 {#    <div class="row">#}
    119 {#        <div class="pagination">#}
    120 {#            <span class="step-links">#}
    121 {#                {% if admin_obj.querysets.has_previous  %}#}
    122 {##}
    123                     {## ————————15PerfectCRM实现King_admin多条件过滤————————#}
    124 {#                     <a href="?page={{ admin_obj.querysets.previous_page_number }}#}
    125 {#                   <a href="?page={{ admin_obj.querysets.previous_page_number }}{%  generate_filter_url admin_obj %}">上一页 </a>#}
    126                      {## ————————15PerfectCRM实现King_admin多条件过滤————————#}
    127 {##}
    128 {#                {% endif %}#}
    129 {##}
    130 {#                <span class="current">#}
    131 {#                    第{{ admin_obj.querysets.number }}页,共{{ admin_obj.querysets.paginator.num_pages }}页#}
    132 {#                </span>#}
    133 {##}
    134 {#                {% if admin_obj.querysets.has_next %}#}
    135 {##}
    136                     {## ————————15PerfectCRM实现King_admin多条件过滤————————#}
    137 {#                    <a href="?page={{ admin_obj.querysets.next_page_number }}#}
    138 {#                    <a href="?page={{ admin_obj.querysets.next_page_number }}{%  generate_filter_url admin_obj %}">下一页</a>#}
    139                        {## ————————15PerfectCRM实现King_admin多条件过滤————————#}
    140 {##}
    141 {#                {% endif %}#}
    142 {#            </span>#}
    143 {#        </div>#}
    144 {#    </div>#}
    145     {## ————————12PerfectCRM实现King_admin分页上下页————————#}
    146 
    147 {## ————————13PerfectCRM实现King_admin分页页数————————#}
    148 {#    <nav aria-label="...">#}
    149 {#      <ul class="pagination">#}
    150 {#        <li class="disabled"></li>#}
    151 {#          {% for  page in admin_obj.querysets.paginator.page_range  %}  {#循环 分页 范围#}
    152 {##}
    153 {#              {% if page == admin_obj.querysets.number  %} {#当前页高亮,否则不加高亮#}
    154 {#                  <li class="active">#}
    155 {#              {% else %}#}
    156 {#                   <li >#}
    157 {#              {% endif %}#}
    158 {##}
    159                                         {#后台拼接返回,kingadmin/templatetags/kingadmin_tags.py 里def generate_filter_url(admin_obj):#}
    160 {#              <a href="?page={{ page }}{%  generate_filter_url admin_obj %}">{{ page }}</a>#}
    161 {#              </li>#}
    162 {#          {% endfor %}#}
    163 {#      </ul>#}
    164 {#    </nav>#}
    165 {## ————————13PerfectCRM实现King_admin分页页数————————#}
    166 
    167 {## ————————14PerfectCRM实现King_admin分页的省略显示————————#}
    168     <div class="row panel-body">
    169         <nav aria-label="...">
    170             <ul class="pagination">
    171                 <!--如果有上一页-->
    172                 {% if admin_obj.querysets.has_previous %}
    173                      {## ————————18PerfectCRM实现King_admin搜索关键字————————#}
    174                     {## ————————17PerfectCRM实现King_admin单列排序————————#}
    175 {#                    <li><a href="?page={{ admin_obj.querysets.previous_page_number }}{% generate_filter_url admin_obj %}"#}
    176 {#                           aria-label="Previous"><span aria-hidden="true">&laquo;</span></a></li>#}
    177 
    178                             {#获取上一个数字#}                         {# kingadmin排序功能 # 过滤后排序功能#排序#}           {#分页#}
    179 {#<li><a href="?page={{ admin_obj.querysets.previous_page_number }}{% generate_order_by_url request  %}{% generate_filter_url admin_obj %}"#}
    180 {#       aria-label="Previous"><span aria-hidden="true">上页</span></a></li>#}
    181                      {## ————————17PerfectCRM实现King_admin单列排序————————#}
    182                     <li><a href="?page={{ admin_obj.querysets.previous_page_number }}
    183 {% generate_order_by_url request  %}{% generate_filter_url admin_obj %}&_q={% get_search_key request %}"
    184                            aria-label="Previous"><span aria-hidden="true">上页</span></a></li>
    185                      {## ————————18PerfectCRM实现King_admin搜索关键字————————#}
    186                 {% else %}
    187                     <li class="disabled">
    188                         <a href="#" aria-label="Previous"><span aria-hidden="true">&laquo;</span></a></li>
    189                 {% endif %}
    190                 <!--#分页的省略显示  kingadmin/templatetags/kingadmin_tags.py里def pag_omit(request,admin_obj):-->
    191                 {% pag_omit request admin_obj %}
    192                 <!--如果有下一页-->
    193                 {% if admin_obj.querysets.has_next %}
    194                  {## ————————18PerfectCRM实现King_admin搜索关键字————————#}
    195                  {## ————————17PerfectCRM实现King_admin单列排序————————#}
    196 {#                    <li><a href="?page={{ admin_obj.querysets.next_page_number }}{% generate_filter_url admin_obj %}"#}
    197 {#                           aria-label="Previous"><span aria-hidden="true">&raquo;</span></a></li>#}
    198 
    199 {#<li><a href="?page={{ admin_obj.querysets.next_page_number }}{% generate_order_by_url request  %}{% generate_filter_url admin_obj %}"#}
    200 {#       aria-label="Previous"><span aria-hidden="true">下页</span></a></li>#}
    201                  {## ————————17PerfectCRM实现King_admin单列排序————————#}
    202                     <li><a href="?page={{ admin_obj.querysets.next_page_number }}
    203 {% generate_order_by_url request  %}{% generate_filter_url admin_obj %}&_q={% get_search_key request %}"
    204                            aria-label="Previous"><span aria-hidden="true">下页</span></a></li>
    205                 {## ————————18PerfectCRM实现King_admin搜索关键字————————#}
    206 
    207                 {% else %}
    208                     <li class="disabled"><a href="#" aria-label="Previous"><span aria-hidden="true">&raquo;</span></a>
    209                     </li>
    210                 {% endif %}
    211             </ul>
    212         </nav>
    213     </div>
    214 {## ————————14PerfectCRM实现King_admin分页的省略显示————————#}
    215 
    216 
    217 {% endblock %}
    218 {## ————————08PerfectCRM实现King_admin显示注册表的字段表头————————#}
    {#table_data_list.html#}

      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搜索关键字————————
    #views

      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         for column in admin_obj.list_display: #循环base_admin里class BaseAdmin下list_display = ()
     66             column_obj = obj._meta.get_field(column)#遍历获取  传进的参数对象
     67 
     68             if column_obj.choices:#判断如果字段有choices属性
     69                 #获取choices的字符串(外健)
     70                 get_column_data = getattr(obj,"get_%s_display" % column) #反射,传进的参数对象,拼接字段
     71                 column_data = get_column_data()#函数,拿到数据
     72             else:
     73                 column_data = getattr(obj, column)#反射,
     74             # ————————10PerfectCRM实现King_admin日期优化————————
     75             if type(column_data).__name__ == 'datetime':
     76                 column_data = column_data.strftime('%Y-%m-%d %H-%M-%S')
     77             # ————————10PerfectCRM实现King_admin日期优化————————
     78 
     79             td_ele = '''<td>%s</td>''' % column_data  #把反射来的值 拼接字符串 生成<td>
     80             row_ele += td_ele    #把 <td>  拼接到上面到空字符串
     81     else:
     82         row_ele +="<td>%s</td>" %obj  #把<td>拼接到上面到空字符串,crm/models.py里 def __str__(self):的返回值
     83     return mark_safe(row_ele) #使用mark_safe函数标记后,django将不再对该函数的内容进行转义
     84 # ————————09PerfectCRM实现King_admin显示注册表的内容————————
     85 
     86 
     87 # ————————13PerfectCRM实现King_admin分页页数————————
     88 #分页功能kingadmin/templates/kingadmin/table_data_list.html里 <a href="?page={{ page }}{%  generate_filter_url admin_obj %}">{{ page }}
     89 @register.simple_tag
     90 def generate_filter_url(admin_obj): #拼接URL
     91     url = ''
     92     for k,v in admin_obj.filter_condtions.items():
     93         url += "&%s=%s" %(k,v )
     94     return url
     95 # ————————13PerfectCRM实现King_admin分页页数————————
     96 
     97 # ————————14PerfectCRM实现King_admin分页的省略显示————————
     98 #分页的省略显示
     99 @register.simple_tag
    100 def pag_omit(request,admin_obj):#传入当前页面值
    101     rest=''#大字符串
    102     # ————————18PerfectCRM实现King_admin搜索关键字————————
    103     search_key = get_search_key(request)  # 搜索
    104     # ————————18PerfectCRM实现King_admin搜索关键字————————
    105     # ————————17PerfectCRM实现King_admin单列排序————————
    106     order_by_url = generate_order_by_url(request)  # 排序
    107     # ————————17PerfectCRM实现King_admin单列排序————————
    108     # ————————15PerfectCRM实现King_admin多条件过滤————————
    109     filters = generate_filter_url(admin_obj)  # 分页
    110     # ————————15PerfectCRM实现King_admin多条件过滤————————
    111     add_tags=False#标志位
    112     for pages in admin_obj.querysets.paginator.page_range:
    113         #   前两页    或   后  两页                                       或    当前页的前后页
    114         if pages < 3 or pages>admin_obj.querysets.paginator.num_pages -2 or abs(admin_obj.querysets.number -pages) <=2:
    115             #样式
    116             add_tags=False
    117             ele_class=''  #颜色
    118             if pages == admin_obj.querysets.number: #--如果是当前页码,颜色加深 不进链接跳转--
    119                 ele_class="active"    #颜色加深
    120             # ————————18PerfectCRM实现King_admin搜索关键字————————
    121             # ————————17PerfectCRM实现King_admin单列排序————————
    122             # ————————15PerfectCRM实现King_admin多条件过滤————————
    123             # rest+='''<li class="%s"><a href="?page=%s">%s</a></li>'''%(ele_class,pages,pages)  #--拼接URL--
    124             # rest+='''<li class="%s"><a href="?page=%s%s">%s</a></li>'''%(ele_class,pages,filters,pages)  #--拼接URL--
    125             # ————————15PerfectCRM实现King_admin多条件过滤————————
    126             # rest+='''<li class="%s"><a href="?page=%s%s%s">%s<span class="sr-only">(current)</span></a></li>'''
    127             #         %(ele_class,pages,order_by_url,filters,pages)
    128             # ————————17PerfectCRM实现King_admin单列排序————————
    129             rest+='''<li class="%s"><a href="?page=%s%s%s&_q=%s">%s<span class="sr-only">(current)</span></a></li>'''
    130                     %(ele_class,pages,order_by_url,filters,search_key,pages)
    131             # ————————18PerfectCRM实现King_admin搜索关键字————————
    132         else:#其他的用省略号表示
    133             if add_tags==False:#如果不是标志位的页面
    134                 rest+='<li><a>...</a></li>'
    135                 add_tags=True#标志位为真
    136     return mark_safe(rest)  #使用mark_safe函数标记后,django将不再对该函数的内容进行转义
    137 
    138 # ————————14PerfectCRM实现King_admin分页的省略显示————————
    139 
    140 
    141 
    142 # # ————————15PerfectCRM实现King_admin多条件过滤————————
    143 # #多条件过滤  table_data_list.html 传递参数
    144 # @register.simple_tag
    145 # def get_filter_field (filter_column,admin_obj):
    146 #     print("admin obj",admin_obj.model ,filter_column)
    147 #     field_obj = admin_obj.model._meta.get_field(filter_column)#调用内置方法
    148 #     select_ele = """<select name="%s"> """ %filter_column #拼接成下拉框返回
    149 #     for choice in field_obj.get_choices():#循环获取crm/models里class Customer(models.Model):下source_choices = ((0,'转介绍'),
    150 #         selected_condtion = admin_obj.filter_condtions.get(filter_column)
    151 #         if selected_condtion != None: #if None, 没有过滤这个条件
    152 #             print("heoe....",filter_column,selected_condtion,type(selected_condtion))#类型是 整数
    153 #             if selected_condtion == str(choice[0]): #就是选择的这个条件,整数转字符串
    154 #                 selected = "selected"
    155 #             else:
    156 #                 selected = ""
    157 #         else:
    158 #             selected = ""
    159 #
    160 # #在前端把几个条件提交到后台,后台拿着条件变成一个字典,然后进行过滤,把数据返回前端,并且把条件作为字典返回后端,因为要在前端显示已经过滤的条件。
    161 #         option_ele = """<option value="%s" %s>%s</option> """ % (choice[0],selected,choice[1])
    162 #         select_ele +=option_ele
    163 #     select_ele += "</select>"
    164 #     return mark_safe(select_ele)
    165 # # ————————15PerfectCRM实现King_admin多条件过滤————————
    166 
    167 # # ————————16PerfectCRM实现King_admin日期过滤————————
    168 from django.utils.timezone import datetime,timedelta
    169 @register.simple_tag
    170 def get_filter_field (filter_column,admin_obj):
    171     select_ele = """<select name='{filter_column}'><option  value="">---------</option>""" #标签 字符串 #拼接成下拉框返回
    172     field_obj = admin_obj.model._meta.get_field(filter_column)#调用内置方法
    173     selected = ''
    174     if field_obj.choices:
    175         for choice_item in field_obj.choices:
    176             if admin_obj.filter_condtions.get(filter_column) == str(choice_item[0]):
    177                 selected = "selected"
    178             select_ele  +=  """<option value="%s" %s>%s</option> """ % (choice_item[0], selected, choice_item[1])
    179             selected = ""
    180 
    181     if type(field_obj).__name__ in "ForeignKey":
    182         for choice_item in field_obj.get_choices()[1:]:
    183             if admin_obj.filter_condtions.get(filter_column)== str(choice_item[0]):  # 就是选择的这个条件,整数转字符串
    184                 selected = "selected"
    185             select_ele += """<option value="%s" %s>%s</option> """ % (choice_item[0], selected, choice_item[1])
    186             selected=''
    187 
    188     if type(field_obj).__name__ in ['DateTimeField', 'DateField']:  # 如果是时间格式
    189         date_els = []  # 日期条件项
    190         today_ele = datetime.now().date()  # 今天日期
    191         date_els.append(['今天', today_ele])  # 今天
    192         date_els.append(['昨天', today_ele - timedelta(days=1)])  # 昨天
    193         date_els.append(['近7天', today_ele - timedelta(days=7)])  # 一周
    194         date_els.append(['近30天', today_ele - timedelta(days=30)])  # 三十
    195         date_els.append(['本月', today_ele.replace(day=1)])  # 本月
    196         date_els.append(['近90天', today_ele - timedelta(days=90)])  # 90天
    197         date_els.append(['近365天', today_ele - timedelta(days=365)])  # 365天
    198         date_els.append(['本年', today_ele.replace(month=1, day=1)])  ##今年
    199 
    200         for choice_item in date_els:
    201             if admin_obj.filter_condtions.get("%s__gte" %filter_column)==str(choice_item[1]):
    202                 selected = 'selected'
    203             select_ele += """<option value="%s" %s>%s</option> """ % (choice_item[1], selected, choice_item[0])
    204             selected = ''
    205         filter_column_name = "%s__gte" %filter_column
    206     else:
    207         filter_column_name = filter_column
    208 
    209     select_ele += "</select>"
    210     select_ele=select_ele.format(filter_column=filter_column_name)#格式化时间的判断条件
    211     return mark_safe(select_ele)
    212 # ————————16PerfectCRM实现King_admin日期过滤————————
    213 
    214 # ————————17PerfectCRM实现King_admin单列排序————————
    215 # kingadmin排序功能
    216 @register.simple_tag
    217 def  get_orderby_key(request,column):
    218     current_order_by_key = request.GET.get("_o")
    219     # ————————18PerfectCRM实现King_admin搜索关键字————————
    220     search_key = request.GET.get("_q")
    221     if search_key != None:
    222         if current_order_by_key != None: #如果不为空  #肯定有某列被排序了
    223             if current_order_by_key ==  column: # 判断是否相等 #当前这列正在被排序
    224                 if column.startswith("-"): #startsWith是String类中的一个方法,用来检测某字符串是否以另一个字符串开始,返回值为boolean类型
    225                     return column.strip("-") #strip去掉  文本中句子开头与结尾的符号的
    226                 else:
    227                     return "-%s&_q=%s" % (column, search_key)
    228         return "%s&_q=%s" % (column, search_key)
    229     else:
    230     # ————————18PerfectCRM实现King_admin搜索关键字————————
    231         if current_order_by_key != None: #如果不为空  #肯定有某列被排序了
    232             if current_order_by_key ==  column: # 判断是否相等 #当前这列正在被排序
    233                 if column.startswith("-"): #startsWith是String类中的一个方法,用来检测某字符串是否以另一个字符串开始,返回值为boolean类型
    234                     return column.strip("-") #strip去掉  文本中句子开头与结尾的符号的
    235                 else:
    236                     return "-%s"%column
    237         #     else:
    238         #         return column
    239         # else:
    240         #     return column
    241         return column   #同上4句
    242 # kingadmin排序功能
    243 
    244 # kingadmin排序功能  显示排序图标
    245 # @register.simple_tag
    246 # def display_order_by_icon(request, column):
    247 #     current_order_by_key = request.GET.get("_o")
    248 #     if current_order_by_key != None: #肯定有某列被排序了
    249 #         if current_order_by_key.strip("-") == column: ## 当前这列正在被排序
    250 #             if current_order_by_key.startswith("-"):
    251 #                 icon = "fa-arrow-up"
    252 #             else:
    253 #                 icon = "fa-arrow-down"
    254 #             ele = """<i class="fa %s" aria-hidden="true"></i>""" % icon
    255 #             return mark_safe(ele)
    256 #     return ''
    257 # kingadmin排序功能  显示排序图标
    258 @register.simple_tag
    259 def display_order_by_icon(request, column):
    260     current_order_by_key = request.GET.get("_o")
    261     if current_order_by_key != None: #肯定有某列被排序了
    262         if current_order_by_key.strip("-") == column: # 当前这列正在被排序  #strip去掉  文本中句子开头与结尾的符号的
    263             if current_order_by_key.startswith("-"): #startsWith是String类中的一个方法,用来检测某字符串是否以另一个字符串开始,返回值为boolean类型
    264                 icon = ""
    265             else:
    266                 icon = ""
    267             ele = """<i style='color: red'>%s</i>""" % icon
    268             return mark_safe(ele)
    269     return '' #防止出现 None
    270 # kingadmin排序功能  显示排序图标
    271 
    272 # kingadmin排序功能  # 过滤后排序功能 #}
    273 @register.simple_tag
    274 def get_current_orderby_key(request): #注意生成的URL问题
    275     #获取当前正在排序的字段名   #<input type="hidden" name="_o" value="{% get_current_orderby_key request %}">
    276     current_order_by_key = request.GET.get("_o")
    277     return current_order_by_key or ''
    278 # kingadmin排序功能  # 过滤后排序功能 #}
    279 
    280 # kingadmin排序功能   # 过滤后排序功能 # 排序分页
    281 @register.simple_tag
    282 def generate_order_by_url (request):
    283     current_order_by_key = request.GET.get("_o")
    284     if current_order_by_key != None:  # 肯定有某列被排序了
    285         return "&_o=%s" % current_order_by_key
    286     return ''
    287 # kingadmin排序功能   # 过滤后排序功能 # 排序分页
    288 # ————————17PerfectCRM实现King_admin单列排序————————
    289 
    290 # ————————18PerfectCRM实现King_admin搜索关键字————————
    291 @register.simple_tag
    292 def get_search_key(request):   #  搜索框里保留搜索值
    293     search_key = request.GET.get("_q")
    294     return search_key or ''
    295 # ————————18PerfectCRM实现King_admin搜索关键字————————
    #kingadmin_tags.py

  • 相关阅读:
    Nginx的启动、停止与重启
    如何修改element.style中的值
    在centos后台运行python程序(nohup)
    Python schedule 模块使用
    「Django」Django内置email发送邮件
    Django内置email发送邮件
    「Django」Xadmin应用
    「Django」浏览+1的操作
    「Vue」watch基本用法
    「Django」contenttypes基本用法
  • 原文地址:https://www.cnblogs.com/ujq3/p/8660428.html
Copyright © 2011-2022 走看看