zoukankan      html  css  js  c++  java
  • Django项目:CRM(客户关系管理系统)--35--27PerfectCRM实现King_admin编辑复选框

     1 #admin.py
     2 
     3 # ————————01PerfectCRM基本配置ADMIN————————
     4 
     5 from django.contrib import admin
     6 # Register your models here.
     7 from crm import models #从crm导入models
     8 
     9 # ————————24PerfectCRM实现King_admin自定义操作数据————————
    10 from django.shortcuts import render
    11 # ————————24PerfectCRM实现King_admin自定义操作数据————————
    12 
    13 # ————————04PerfectCRM实现King_admin注册功能————————
    14 class CustomerAdmin(admin.ModelAdmin):#定制Djanago admin
    15     list_display = ('id','qq','source','consultant','content','date')#显示字段表头
    16     # ————————11PerfectCRM实现King_admin分页显示条数————————
    17     list_per_page = 2  #分页条数
    18     # ————————11PerfectCRM实现King_admin分页显示条数————————
    19     # ————————16PerfectCRM实现King_admin日期过滤————————
    20     # ————————15PerfectCRM实现King_admin多条件过滤————————
    21     # 过滤器(可以包含ManyToManyField) (注意加 逗号 , )
    22     # list_filter = ('source','consultant','consult_courses',)
    23     list_filter = ('date','source','consultant','consult_courses',)
    24     # ————————15PerfectCRM实现King_admin多条件过滤————————
    25     # ————————16PerfectCRM实现King_admin日期过滤————————
    26     # ————————18PerfectCRM实现King_admin搜索关键字————————
    27     #搜索(不能包含CharField)(注意加 逗号 , )
    28     search_fields = ('name','qq',)
    29     # ————————18PerfectCRM实现King_admin搜索关键字————————
    30 
    31     # ————————26PerfectCRM实现King_admin自定义排序————————
    32     ordering = ['-qq'] #自定义排序,默认'-id'
    33     # ————————26PerfectCRM实现King_admin自定义排序————————
    34 
    35     # ————————27PerfectCRM实现King_admin编辑复选框————————
    36     filter_horizontal = ('tags',) #复选框
    37     # ————————27PerfectCRM实现King_admin编辑复选框————————
    38     
    39 
    40 
    41     # ————————24PerfectCRM实现King_admin自定义操作数据————————
    42     # from django.shortcuts import render
    43     actions = ['test_actions',]#定制功能    #测试返回到一个新页面
    44     def test_actions(self,request,arg2):#对应的函数 #request类自己的请求  #arg2类的内容
    45         return render(request,"king_admin/table_index.html")
    46     test_actions.short_description = "测试显示中文"
    47     # ————————24PerfectCRM实现King_admin自定义操作数据————————
    48 
    49 
    50 # ————————04PerfectCRM实现King_admin注册功能————————
    51 
    52 #注册到 Django Admin里
    53 admin.site.register(models.Branch)                  #01校区表
    54 admin.site.register(models.ClassList)               #02班级表
    55 admin.site.register(models.Course)                  #03课程表,可以报名那些课程
    56 
    57 # ————————04PerfectCRM实现King_admin注册功能————————
    58 # admin.site.register(models.Customer)                #04客户信息表
    59 admin.site.register(models.Customer,CustomerAdmin)                #04客户信息表
    60 # ————————04PerfectCRM实现King_admin注册功能————————
    61 
    62 admin.site.register(models.CustomerFollowUp)        #05客户跟进表
    63 admin.site.register(models.Enrollment)              #06学员报名信息表
    64 admin.site.register(models.Payment)                 #07缴费记录表
    65 admin.site.register(models.CourseRecord)            #08每节课上课纪录表
    66 admin.site.register(models.StudyRecord)             #09学习纪录
    67 admin.site.register(models.UserProfile)             #10账号表
    68 admin.site.register(models.Role)                    #11角色表
    69 admin.site.register(models.Tag)                     #12标签表
    70 
    71 '''
    72 Django Admin里账号密码重置方法
    73 #运行 Terminal  
    74 
    75 python manage.py createsuperuser
    76 
    77 Username :              admin
    78 Email address:          admin@qq.com
    79 Password:               admin123456
    80 Password (again):       admin123456
    81 
    82 
    83 英文转中文方法
    84 到settings.py里修改
    85 # LANGUAGE_CODE = 'en-us'
    86 LANGUAGE_CODE = 'zh-Hans'
    87 '''
    88 
    89 # ————————01PerfectCRM基本配置ADMIN————————
    #admin.py

     1 # kingadmin.py
     2 # ————————04PerfectCRM实现King_admin注册功能————————
     3 from crm import models
     4 #print("kingadmin crm",models.Customer)
     5 
     6 # ————————05PerfectCRM实现King_admin注册功能获取内存————————
     7 # from king_admin.base_admin import register,BaseAdmin
     8 from king_admin.base_admin import site,BaseAdmin
     9 # ————————05PerfectCRM实现King_admin注册功能获取内存————————
    10 
    11 # ————————24PerfectCRM实现King_admin自定义操作数据————————
    12 from django.shortcuts import render
    13 # ————————24PerfectCRM实现King_admin自定义操作数据————————
    14 
    15 #04客户信息表
    16 class CustomerAdmin(BaseAdmin):#定制Djanago admin
    17     list_display = ('id', 'qq', 'source', 'consultant', 'content', 'date')  # 显示字段表头
    18 
    19     # ————————11PerfectCRM实现King_admin分页显示条数————————
    20     list_per_page = 2  #分页条数  # 默认分页条数10
    21     # ————————11PerfectCRM实现King_admin分页显示条数————————
    22 
    23     # ————————16PerfectCRM实现King_admin日期过滤————————
    24     # ————————15PerfectCRM实现King_admin多条件过滤————————
    25     # 过滤器(可以包含ManyToManyField) (注意加 逗号 , )
    26     # list_filter = ('source','consultant','consult_courses',)
    27     list_filter = ('date','source','consultant','consult_courses',)
    28     # ————————15PerfectCRM实现King_admin多条件过滤————————
    29     # ————————16PerfectCRM实现King_admin日期过滤————————
    30 
    31     # ————————18PerfectCRM实现King_admin搜索关键字————————
    32     #搜索(不能包含CharField)(注意加 逗号 , )
    33     search_fields = ('name','qq',)
    34     # ————————18PerfectCRM实现King_admin搜索关键字————————
    35 
    36     # ————————26PerfectCRM实现King_admin自定义排序————————
    37     ordering = '-qq'  #自定义排序,默认'-id'
    38     # ————————26PerfectCRM实现King_admin自定义排序————————
    39 
    40     # ————————27PerfectCRM实现King_admin编辑复选框————————
    41     filter_horizontal = ('tags',) #复选框
    42     # ————————27PerfectCRM实现King_admin编辑复选框————————
    43 
    44     # ————————24PerfectCRM实现King_admin自定义操作数据————————
    45     # from django.shortcuts import render
    46     actions = ['test_actions',]#定制功能    #测试返回到一个新页面
    47     def test_actions(self,request,arg2):#对应的函数 #request类自己的请求  #arg2类的内容
    48         return render(request,"king_admin/table_index.html")
    49     test_actions.short_description = "测试显示中文"
    50     # ————————24PerfectCRM实现King_admin自定义操作数据————————
    51 
    52     
    53 
    54 # ————————05PerfectCRM实现King_admin注册功能获取内存————————
    55 # register(models.Customer,CustomerAdmin)
    56 # register(models.CourseRecord)
    57 site.register(models.Customer,CustomerAdmin)
    58 site.register(models.CourseRecord)
    59 # ————————05PerfectCRM实现King_admin注册功能获取内存————————
    60 
    61 # ————————04PerfectCRM实现King_admin注册功能————————
    # kingadmin.py

      1 #base_admin.py
      2 
      3 
      4 # ————————24PerfectCRM实现King_admin自定义操作数据————————
      5 from django.shortcuts import render,redirect
      6 # ————————24PerfectCRM实现King_admin自定义操作数据————————
      7 
      8 # ————————04PerfectCRM实现King_admin注册功能————————
      9 
     10 #Django admin 注册功能的形式
     11 # sites = {
     12 #     'crm':{
     13 #         'customers':CustomerAdmin,
     14 #         'customerfollowup':CustomerFollowUPAdmin,
     15 #     }
     16 # }
     17 
     18 class AdminRegisterException(Exception):  #自定义异常
     19     def __init__(self,msg):
     20         self.message = msg
     21 
     22 class BaseAdmin(object):#自定义方法
     23     list_display = ()  #显示的字段(不能包含ManyToManyField)
     24 
     25     # ————————11PerfectCRM实现King_admin分页显示条数————————
     26     list_per_page = 10  # 默认分页条数10
     27     # ————————11PerfectCRM实现King_admin分页显示条数————————
     28 
     29     # ————————15PerfectCRM实现King_admin多条件过滤————————
     30     list_filter = ()        # 过滤器(可以包含ManyToManyField) (注意加 逗号 , )
     31     # ————————15PerfectCRM实现King_admin多条件过滤————————
     32 
     33     # ————————18PerfectCRM实现King_admin搜索关键字————————
     34     search_fields = () #搜索(不能包含CharField)(注意加 逗号 , )
     35     # ————————18PerfectCRM实现King_admin搜索关键字————————
     36 
     37     # ————————26PerfectCRM实现King_admin自定义排序————————
     38     ordering = None    #自定义排序
     39     # ————————26PerfectCRM实现King_admin自定义排序————————
     40 
     41     # ————————27PerfectCRM实现King_admin编辑复选框————————
     42     filter_horizontal = []#复选框
     43     # ————————27PerfectCRM实现King_admin编辑复选框————————
     44 
     45     # ————————24PerfectCRM实现King_admin自定义操作数据————————
     46     actions = []#自定功能
     47 
     48     default_actions = ["delete_selected",]  #默认删除的函数
     49     #默认删除的函数
     50     def delete_selected(self,request,queryset):
     51         # from django.shortcuts import render, redirect
     52         print("goint to delete ",queryset)
     53         app_name=self.model._meta.app_label#app名
     54         model_name=self.model._meta.model_name#表名
     55         objs=queryset#类对象
     56         action=request._admin_action
     57         print(action,'<-------action')
     58         if request.POST.get('delete_confirm')=='yes': #{#table_delete.html#}
     59             queryset.delete()
     60             return redirect('/king_admin/%s/%s/'%(app_name,model_name))
     61         selected_ids=','.join([str(i.id) for i in queryset])
     62         print(selected_ids,'<---selected_ids')
     63         objs=queryset
     64         return render(request,"king_admin/table_delete.html", locals())  #返回删除页
     65     delete_selected.short_description = "默认批量删除"
     66     # ————————24PerfectCRM实现King_admin自定义操作数据————————
     67 
     68     
     69 # ————————05PerfectCRM实现King_admin注册功能获取内存————————
     70 class AdminSite(object):
     71     def __init__(self):
     72         self.registered_sites = {}   #传到views 里调用
     73     def register(self,model,admin_class=None): #默认值None 使用 BaseAdmin
     74         app_name = model._meta.app_label#用内置方法获取 APP名字 (crm)
     75         model_name = model._meta.model_name#用内置方法获取 表名  (Customer)
     76         if app_name not in self.registered_sites:
     77             self.registered_sites[app_name] = {} #创建  crm={}
     78         if model_name in self.registered_sites[app_name]:
     79             raise AdminRegisterException("app [%s] model [%s] has already registered!异常"
     80                                                  %(app_name,model_name))#自定义异常,
     81         if not  admin_class:
     82             admin_class = BaseAdmin  #默认值None 使用 BaseAdmin
     83         # self.registered_sites[app_name][model_name] = admin_class #注册APP
     84 # site = AdminSite()  # 实例化类  单例模式
     85 
     86 
     87         # ————————05PerfectCRM实现King_admin注册功能获取内存————————
     88         #registered_sites {'crm': {'customer': <class 'crm.kingadmin.CustomerAdmin'>, 'courserecord': <class 'kingadmin.base_admin.BaseAdmin'>}}
     89         #把类名放到class的对象里,然后通过class的对象传到前端
     90 #         admin_class.model = model
     91 #         self.registered_sites[app_name][model_name] = admin_class #注册APP
     92 #
     93 # site = AdminSite() #实例化类  单例模式
     94         # ————————05PerfectCRM实现King_admin注册功能获取内存————————
     95 
     96         # ————————06PerfectCRM实现King_admin注册功能获取内存优化处理————————
     97         #没有实例化会使用同一个内存地址
     98         admin_obj = admin_class()  #先实例化
     99         admin_obj.model = model    #参数赋值给实例
    100         self.registered_sites[app_name][model_name] = admin_obj#注册APP
    101         #实例化后,调用会使用不同的内存地址
    102 
    103 site = AdminSite() #实例化类  单例模式
    104         # ————————06PerfectCRM实现King_admin注册功能获取内存优化处理————————
    105         
    106 # registered_sites={}
    107 # def register(model,admin_class=None): #默认值None 使用 BaseAdmin
    108 #     app_name = model._meta.app_label#用内置方法获取 APP名字 (crm)
    109 #     model_name = model._meta.model_name#用内置方法获取 表名  (Customer)
    110 #     if app_name not in registered_sites:
    111 #         registered_sites[app_name] = {} #创建  crm={}
    112 #     if model_name in registered_sites[app_name]:
    113 #         raise AdminRegisterException("app [%s] model [%s] has already registered!异常"
    114 #                                              %(app_name,model_name))#自定义异常
    115 #     if not admin_class:
    116 #         admin_class = BaseAdmin  #默认值None 使用class BaseAdmin
    117 #     registered_sites[app_name][model_name] = admin_class #注册APP
    118 
    119 # ————————05PerfectCRM实现King_admin注册功能获取内存————————
    120 
    121 # ————————04PerfectCRM实现King_admin注册功能————————
    #base_admin.py

      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 
     18 
     19 
     20 {% block right-container-content %}
     21     <div class="row" style="margin-bottom: 20px" >
     22         <ol class="breadcrumb">
     23           <li><a href="/king_admin/">主页</a></li>
     24           <li><a href="/king_admin/{% get_app_name admin_obj.model %}/">{% get_app_name admin_obj.model %}</a></li>
     25           <li><a href="/king_admin/{% get_app_name admin_obj.model %}/{% get_model_name admin_obj.model %}/">
     26                 {% get_model_verbose_name admin_obj.model %} </a></li>
     27             {% if not admin_obj.is_add_form %} {#  新建时 ForeignKey不能实例化 #}
     28                <li class="active">{{ obj_form.instance }}</li>  {#  修改时 实例化 #}
     29             {% endif %}
     30         </ol>
     31          {## ————————25PerfectCRM实现King_admin添加出错修复————————#}
     32 {#        <h4>修改:{% get_model_verbose_name admin_obj.model  %}</h4>#}
     33 
     34         {% block Tops %}
     35             <div class="panel panel-info">
     36                 <h4 style='color: red'>修改: {% get_model_verbose_name admin_obj.model %}</h4>
     37             </div>
     38         {% endblock %}
     39          {## ————————25PerfectCRM实现King_admin添加出错修复————————#}
     40     </div>
     41 
     42    <div class="row">
     43         {{ obj_form.errors  }}
     44 
     45         {## ————————27PerfectCRM实现King_admin编辑复选框————————#}
     46         {#<form class="form-horizontal" method="post" >{% csrf_token %}#}
     47         <form class="form-horizontal" method="post" onsubmit="return BeforeFormSubmit(this);">{% csrf_token %}
     48         {## ————————27PerfectCRM实现King_admin编辑复选框————————#}
     49         
     50             {% for field in obj_form %}
     51                   <div class="form-group">
     52                     <label  class="col-sm-2 " style="font-weight: normal"> {#字体#}
     53                         {% if field.field.required %}   {#required判断是不是必须填写#}
     54                             <b>{{ field.label }}</b>
     55                         {% else %}
     56                             {{ field.label }}
     57                         {% endif %}
     58 
     59                     </label>
     60                     <div class="col-sm-10" >
     61                         <span style="color: red;">{{ field.errors }}</span>
     62 
     63 
     64 
     65                         {## ————————27PerfectCRM实现King_admin编辑复选框————————#}
     66 {#                            {{ field }}#}
     67                         {% if field.name in admin_obj.filter_horizontal %} <!-- 水平--><!--     判断是否复选框-->
     68                             {% get_m2m_chosen_objs admin_obj field.name obj_form.instance as m2m_chosen_objs %} <!--当前对象已经选中的字段名-->
     69                             <!--    左边待选框-->
     70                             <div class="col-md-6">
     71                             <!--    取所有的内容-->
     72                                 {% get_m2m_available_objs admin_obj field.name as m2m_available_objs %}
     73 {#                                <input type="text" oninput="FuzzSearch(this,'id_{{ field.name }}_from')" class="form-control">#}
     74                             <!--                                   字段名-->
     75                                 <select multiple field_name="{{ field.name }}" class="form-control filter-select-box" id="id_{{ field.name }}_from" >
     76                                     <!-- 字段名 是否为不能修改-->
     77                                     {% if field.name in admin_obj.readonly_fields and not admin_obj.is_add_form %}
     78                                         {% for obj in m2m_available_objs  %}
     79                                             {% if obj not in m2m_chosen_objs %}<!--不在当象已经选中的字段名 才显示-->
     80                                                 <option value="{{ obj.id }}" disabled>{{ obj }}</option>
     81                                             {% endif %}
     82                                         {% endfor %}
     83                                     {% else %}
     84                                         {% for obj in m2m_available_objs %}
     85                                             {% if obj not in m2m_chosen_objs %}<!--不在当象已经选中的字段名 才显示-->
     86                                                 <option value="{{ obj.id }}" ondblclick="MoveEleTo(this,'id_{{ field.name }}_to')">{{ obj }}</option>
     87                                             {% endif %}
     88                                         {% endfor %}
     89                                     {% endif %}
     90                                 </select>
     91                             </div>
     92                             <!--    中间箭头-->
     93                             <div class="col-md-1">
     94                                 <div><h4 style='color: #00ff06'>待选 ->  </h4></div>
     95                                 <div><h4 style='color: #8dffc5'>双击选择 </h4></div>
     96                                 <div><h4 style='color: #ff0003'> <- 已选 </h4></div>
     97                             </div>
     98 
     99                             <!--    右边已选框-->
    100                             <div class="col-md-5">
    101                                 <select m2m_right="yes" name="{{ field.name }}" multiple field_name="{{ field.name }}" class="form-control" id="id_{{ field.name }}_to">
    102                                     {% if field.name in admin_obj.readonly_fields and not admin_obj.is_add_form %}
    103                                         {% for obj in m2m_chosen_objs %}
    104                                          <option value="{{ obj.id }}" disabled>{{ obj }}</option>
    105                                         {% endfor %}
    106                                     {% else %}
    107 
    108                                         {% for obj in m2m_chosen_objs %}
    109                                             <option value="{{ obj.id }}" ondblclick="MoveEleTo(this,'id_{{ field.name }}_from')">{{ obj }}</option>
    110                                         {% endfor %}
    111                                     {% endif %}
    112                                 </select>
    113 
    114                             </div>
    115 
    116                         {% else %}
    117                             {{ field }} <span style="color: #bce8f1"> {{ field.help_text }}</span>
    118 {#                            <span style="color:red">{{ field.errors }}</span>#}
    119                         {% endif %} <!--     判断是否复选框-->
    120                         {## ————————27PerfectCRM实现King_admin编辑复选框————————#}
    121 
    122 
    123 
    124                     </div>
    125                   </div>
    126             {% endfor %}
    127 
    128             {## ————————25PerfectCRM实现King_admin添加出错修复————————#}
    129             {## ————————23PerfectCRM实现King_admin数据删除————————#}
    130 {#            <a class="btn btn-danger" href="{% url 'table_delete' app_name model_name obj_form.instance.id %}">删除</a>#}
    131            {## ————————23PerfectCRM实现King_admin数据删除————————#}
    132 {#            <input type="submit" value="保存" class="pull-right btn btn-info" >   {#放右边#}
    133 
    134             <div class="form-group">
    135                 {% block del %}
    136                     <div class="col-sm-2">
    137                         <a class="btn btn-danger" href="{% url 'table_delete' app_name model_name obj_form.instance.id %}">删除</a>
    138                     </div>
    139                 {% endblock %}
    140                 <div class="col-sm-10">
    141                     <input type="submit" value="保存" class="pull-right btn btn-info">
    142                 </div>
    143             </div>
    144             {## ————————25PerfectCRM实现King_admin添加出错修复————————#}
    145 
    146         </form>
    147    </div>
    148 
    149 
    150 
    151     
    152 
    153 {% endblock %}
    154 {## ————————20PerfectCRM实现King_admin数据修改美化————————#}
    {#table_change.html#}

     1 {#king_base.html#}
     2 {## ————————02PerfectCRM创建ADMIN页面————————#}
     3 {#模板文件  king_base.html#}
     4 <!DOCTYPE html>
     5 <html lang="zh-CN">
     6     <head>
     7 {#      <meta> 元素可提供有关页面的元信息(meta-information),比如针对搜索引擎和更新频度的描述和关键词。#}
     8 {#      <meta> 标签位于文档的头部,不包含任何内容。<meta> 标签的属性定义了与文档相关联的名称/值对。#}
     9         <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    10         <meta http-equiv="X-UA-Compatible" content="IE=edge">
    11         <meta name="viewport" content="width=device-width, initial-scale=1">
    12         <meta name="description" content="">
    13         <meta name="author" content="">
    14 
    15         <link rel="icon" href="/static/king_img/king_logo.jpg">{# icon,指的是图标 #}
    16         <title>KingAdmin</title> {# 页面头部显示#}
    17 
    18 {#        使用link来调用外部的css文件#}
    19         <link rel="stylesheet"  href="/static/king_css/bootstrap.css"  /> {#导航栏样式#}
    20         <link rel="stylesheet"  href="/static/king_css/dashboard.css" /> {#指示板样式#}
    21 
    22         {## ————————27PerfectCRM实现King_admin编辑复选框————————#}
    23         <link rel="stylesheet"  href="/static/king_css/king_admin_change.css" /> {#编辑复选框样式#}
    24         {## ————————27PerfectCRM实现King_admin编辑复选框————————#}
    25 
    26 
    27 
    28     </head>
    29 
    30     <body>
    31 
    32         {% block body %}{#自定义内容 body#}{% endblock %}
    33 
    34 {#        将纯JavaScript的语句另外保存在一个"*.js"的文件中,需要时再调用。#}
    35         <script src="/static/king_js/jquery.js"></script>   {# jQuery 是一个 JavaScript库,极大地简化了 JavaScript 编程。#}
    36         <script src="/static/king_js/bootstrap.js"></script>  {#指示板JS事件#}
    37 
    38         {## ————————24PerfectCRM实现King_admin自定义操作数据————————#}
    39         <script src="/static/king_js/king_admin_js.js"></script>  {#自定义JS事件#}
    40         {## ————————24PerfectCRM实现King_admin自定义操作数据————————#}
    41         
    42         {## ————————27PerfectCRM实现King_admin编辑复选框————————#}
    43         <script src="/static/king_js/king_admin_change.js"></script>  {#编辑复选框JS事件#}
    44         {## ————————27PerfectCRM实现King_admin编辑复选框————————#}
    45 
    46 
    47     </body>
    48 </html>
    49 
    50 {## ————————02PerfectCRM创建ADMIN页面————————#}
    {#king_base.html#}

     1 /*king_admin_change.css*/
     2 
     3 
     4 /*# ————————27PerfectCRM实现King_admin编辑复选框————————*/
     5 .filter-select-box{
     6     height: 230px;!important;
     7     width:100%;
     8 }
     9 
    10 /*# ————————27PerfectCRM实现King_admin编辑复选框————————*/
    /*king_admin_change.css*/

     1 // king_admin_change.js
     2 // # ————————27PerfectCRM实现King_admin编辑复选框————————
     3         function BeforeFormSubmit(form_ele) {
     4 
     5             console.log(form_ele);
     6             //$('form input[disabled]').prop("disabled", false);//修改为可提交
     7             $("form").find("[disabled]").removeAttr("disabled");//修改为    可提交
     8 
     9             $('select[m2m_right="yes"] option').prop('selected', true);
    10 
    11             return true;
    12         }
    13 
    14 
    15         function MoveEleTo(from_ele, target_ele_id) {
    16             //move options from from_ele to target ele
    17             var field_name = $(from_ele).parent().attr("field_name");//获option名
    18             if (target_ele_id.endsWith('_from')) {//判断是否
    19                 var new_target_id = "id_" + field_name + "_to";
    20             } else {
    21                 var new_target_id = "id_" + field_name + "_from";
    22             }
    23             //创建一个新标签
    24             var opt_ele = "<option value='" + $(from_ele).val() + "'  ondblclick=MoveEleTo(this,'" + new_target_id + "')  >" + $(from_ele).text() + "</option>";
    25             $("#" + target_ele_id).append(opt_ele);//添加到另一边选框
    26             $(from_ele).remove();//移除选中的
    27 
    28         }
    29 
    30 // # ————————27PerfectCRM实现King_admin编辑复选框————————
    // king_admin_change.js

      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数据删除————————
    406 
    407 
    408 # ————————24PerfectCRM实现King_admin自定义操作数据————————
    409 #自定制 actions功能 显示
    410 @register.simple_tag
    411 def get_admin_actions(admin_obj):
    412     #选择功能
    413     options = "<option class='form-control' value='-1'>-------</option>"#默认为空
    414     actions = admin_obj.default_actions + admin_obj.actions #默认加自定制
    415     print('默认加自定制',actions)
    416     for action in actions:
    417         action_func = getattr(admin_obj,action)#功能方法  #反射
    418         if hasattr(action_func,"short_description"):#反射 如有自定义的名称执行函数方法
    419             action_name = action_func.short_description#等于自定义的名称 #显示中文
    420         else:
    421             action_name = action#等于函数名称
    422         options += """<option value="{action_func_name}">{action_name}</option> """.format(action_func_name=action,                                                                                                                                                                                     action_name=action_name)
    423     return mark_safe(options)
    424 # ————————24PerfectCRM实现King_admin自定义操作数据————————
    425 
    426 
    427 
    428 # ————————27PerfectCRM实现King_admin编辑复选框————————
    429 # 复选 框内容待选数据
    430 @register.simple_tag
    431 def get_m2m_available_objs(admin_obj, field_name):
    432     '''返回m2m左侧所有待选数据'''
    433     # c= admin_obj.model.tags.rel.model.objects.all()
    434     # print('c',c)
    435     # m2m_objs= admin_obj.model.tags.rel.model.objects.all()
    436     # print('m2m_objs',m2m_objs)
    437     m2m_model = getattr(admin_obj.model, field_name).rel  # 复选框对象
    438     m2m_objs = m2m_model.model.objects.all()  # 获取到复选框所有内容
    439     return m2m_objs
    440 
    441 
    442 # 复选 框内容已选中数据
    443 @register.simple_tag
    444 def get_m2m_chosen_objs(admin_obj, field_name, obj):
    445     """
    446     返回已选中的列表
    447     :param admin_obj:
    448     :param field_name:
    449     :param obj: 数据对象
    450     :return:
    451     """
    452     # print(["--->obj",obj])
    453     if obj.id:
    454         return getattr(obj, field_name).all()  # 返回所有的内容
    455     return []  # 没有数据为返回空   创建新的记录使用
    456 # ————————27PerfectCRM实现King_admin编辑复选框————————
    #kingadmin_tags.py

  • 相关阅读:
    新东西-intel edison
    MFC AfxMessageBox(_T("Please Load Rawdata First !"));
    libgl1-mesa-glx:i386 : 依赖: libglapi-mesa:i386
    开源硬件_瑞芯微开发板
    手机方案商
    嵌入式Linux应用开发__求职要求
    工作要求
    Proc文件系统接口调试
    Sysfs文件系统接口调试
    Ubuntu Linux 解决 bash ./ 没有那个文件或目录 的方法
  • 原文地址:https://www.cnblogs.com/ujq3/p/8695050.html
Copyright © 2011-2022 走看看