# forms.py
# ————————19PerfectCRM实现King_admin数据修改————————
from django import forms
from crm import models # class CustomerModelForm(forms.ModelForm):
# class Meta: #调用内置方法
# model = models.Customer #获取表名
# fields = "__all__" #字段 # ————————32PerfectCRM实现King_admin添加不进行限制————————
def CreateModelForm(request,admin_obj): # 添加不进行限制到views里处理
# ————————32PerfectCRM实现King_admin添加不进行限制———————— class Meta: #调用内置方法
model = admin_obj.model #获取表名
fields = "__all__" #字段 # ————————20PerfectCRM实现King_admin数据修改美化————————
# type()就是一个最实用又简单的查看数据类型的方法。type()是一个内建的函数,调用它就能够得到一个反回值,从而知道想要查询的对像类型信息。
# dynamic_model_form = type("DynamicModelForm", (forms.ModelForm,), {"Meta": Meta}) #生成modelform的类,
# new()方法是在类准备将自身实例化时调用。new()方法始终都是类的静态方法,即使没有被加上静态方法装饰器。
def __new__(cls, *args, **kwargs):#重写 函数生成方法
# print("base fields",cls.base_fields)
# 字段名 #字段数据
for field_name, field_obj in cls.base_fields.items():
# print(field_name,dir(field_obj))
field_obj.widget.attrs['class'] = 'form-control' # 前端的样式
# field_obj.widget.attrs['maxlength'] = getattr(field_obj,'max_length' ) if hasattr(field_obj,'max_length') \
# else "" # ————————32PerfectCRM实现King_admin添加不进行限制————————
if not hasattr(admin_obj, "is_add_form"): # 如果不是为新增表单
# ————————28PerfectCRM实现King_admin编辑限制————————
if field_name in admin_obj.readonly_fields:#如果,在
field_obj.widget.attrs['disabled'] = True
# ————————28PerfectCRM实现King_admin编辑限制————————
# ————————32PerfectCRM实现King_admin添加不进行限制———————— return forms.ModelForm.__new__(cls) # ————————28PerfectCRM实现King_admin编辑限制————————
def default_clean(self):
#给所有的form默认加一个 clean 验证 # ————————29PerfectCRM实现King_admin编辑自定义限制————————
from django.forms import ValidationError
error_list = []
# ————————29PerfectCRM实现King_admin编辑自定义限制———————— # ————————30PerfectCRM实现King_admin编辑自定义字段验证———————— # ————————32PerfectCRM实现King_admin添加不进行限制————————
if self.instance.id: # 表示为修改表单
# ————————32PerfectCRM实现King_admin添加不进行限制———————— for field in admin_obj.readonly_fields: # 如果是不可修改的字段
# print("readonly",field,self.instance)
# field_val_from_db = getattr(self.instance,field)#取数据库中的值
field_val_from_db = getattr(self.instance, field) # 取数据库中的值
field_val = self.cleaned_data.get(field) # 前端传来的值 # ————————31PerfectCRM实现King_admin编辑多对多限制————————
if hasattr(field_val_from_db,'select_related'):#多对多
m2m_objs=getattr(field_val_from_db,'select_related')().select_related()#调用多对多,获取对应的值
m2m_vals=[i[0] for i in m2m_objs.values_list('id')]#转为列表
set_m2m_vals=set(m2m_vals)#转集合 交集 数据库 # vals_from_frontend=self.cleaned_data.get(field)#前端的值 交集
# m2m_vals=[i[0] for i in vals_from_frontend.values_list('id')]#转为列表
# print(vals_from_frontend,'前端的值 交集',m2m_vals) set_m2m_vals_from_frontend=set([i.id for i in self.cleaned_data.get(field)])#前端的值 交集
from django.utils.translation import ugettext as _ # 国际化
if set_m2m_vals != set_m2m_vals_from_frontend:
error_list.append(ValidationError(
_("%(field)s: 该字段不可修改!"),
code='invalid',
params={'field':field,}
))
self.add_error(field,"不可修改!")
continue #field_val = self.cleaned_data.get(field)#前端传来的值
#print('field_val',type(field_val))
if field_val_from_db != field_val:
print("field not change ")#不一致
error_list.append(ValidationError(#添加错误信息
_("该字段%(field)s 不可修改,原值为: %(val)s"),
code='invalid',
params={'field':field,'val':field_val_from_db}
)) # else: # 被篡改了
# self.add_error(field,' "%s" is a readonly field ,value should be "%s" '% (field, field_val_from_db)) # ————————31PerfectCRM实现King_admin编辑多对多限制———————— #print("cleaned data:",self.cleaned_data,)#要验证的表单
for field in self.cleaned_data:#单独字段
if hasattr(admin_obj,'clean_%s'%field):#是否有该字段的单独验证
field_clean_func=getattr(admin_obj,'clean_%s'%field)#获取对应的函数
response=field_clean_func(self)#
if response:
error_list.append(response)
if error_list:
raise ValidationError(error_list)
#response_sol=admin_obj.('clean_%s'%field)(self.cleaned_data)
# ————————30PerfectCRM实现King_admin编辑自定义字段验证———————— # ————————31PerfectCRM实现King_admin编辑多对多限制————————
# print("default clean:",self)#得到整个form数据
# for field in admin_obj.readonly_fields:#循环获取crm/kingadmin.py里 readonly_fields = ('name','qq',)的数据
# print("readonly",field,self.instance)#获取到 字段名 ,对象(值)
# field_val_from_db = getattr(self.instance,field)#获取数据库的值
# print("cleaned data:", self.cleaned_data)#获取到 前端的值
# field_val = self.cleaned_data.get(field)#获取到 前端的值
#
# if field_val_from_db == field_val:#数据库的值和前端的值对比
# print("数据库数据和前端数据一样 ")
# else: # 被篡改了
# self.add_error(field,' "%s" 是一个只读的字段,值应该是 "%s"! 大神请不要篡改!!!'% (field, field_val_from_db))
# ————————31PerfectCRM实现King_admin编辑多对多限制———————— # ————————29PerfectCRM实现King_admin编辑自定义限制————————
response=admin_obj.default_form_validation(self)#可自定制
if response:
error_list.append(response)
if error_list:
raise ValidationError(error_list)
# ————————29PerfectCRM实现King_admin编辑自定义限制———————— # ————————28PerfectCRM实现King_admin编辑限制———————— dynamic_model_form = type("DynamicModelForm", (forms.ModelForm,), {"Meta": Meta}) # 生成modelform的类,
setattr(dynamic_model_form, "__new__", __new__)
# ————————20PerfectCRM实现King_admin数据修改美化———————— # ————————28PerfectCRM实现King_admin编辑限制————————
setattr(dynamic_model_form,"clean",default_clean) #给所有的form默认加一个 clean 验证
# ————————28PerfectCRM实现King_admin编辑限制————— return dynamic_model_form
# ————————19PerfectCRM实现King_admin数据修改————————

# forms.py

 #views

 # ————————02PerfectCRM创建ADMIN页面————————
from django.shortcuts import render # ————————04PerfectCRM实现King_admin注册功能————————
# from django import conf #配置文件
# print("dj conf:",conf) #配置文件
# print("dj conf:",conf.settings)#配置文件.设置
# ————————04PerfectCRM实现King_admin注册功能———————— # ————————04PerfectCRM实现King_admin注册功能————————
from king_admin import app_config #自动调用 动态加载类和函数
# ————————04PerfectCRM实现King_admin注册功能———————— # ————————04PerfectCRM实现King_admin注册功能————————
# from king_admin.base_admin import registered_sites # registered_sites={}
from king_admin import base_admin
# ————————04PerfectCRM实现King_admin注册功能———————— # ————————11PerfectCRM实现King_admin基本分页————————
from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger # 分页功能
# ————————11PerfectCRM实现King_admin基本分页———————— def app_index(request):
# ————————04PerfectCRM实现King_admin注册功能————————
# for app in conf.settings.INSTALLED_APPS:
# print(app)#循环打印 配置文件.设置.安装应用程序#.Perfectcustomer\settings里的INSTALLED_APPS列表
# ————————04PerfectCRM实现King_admin注册功能———————— # ————————04PerfectCRM实现King_admin注册功能————————
# return render(request, 'king_admin/app_index.html')
# print("registered_sites",registered_sites)
# return render(request, 'king_admin/app_index.html')
# ————————04PerfectCRM实现King_admin注册功能———————— # ————————04PerfectCRM实现King_admin注册功能————————
# print("registered_sites", base_admin.registered_sites)
# return render(request, 'king_admin/app_index.html')
# ————————04PerfectCRM实现King_admin注册功能———————— # ————————05PerfectCRM实现King_admin注册功能获取内存————————
print("registered_sites",base_admin.site.registered_sites)
return render(request, 'king_admin/app_index.html', {"site": base_admin.site})
# ————————05PerfectCRM实现King_admin注册功能获取内存———————— # ————————02PerfectCRM创建ADMIN页面———————— # ————————13PerfectCRM实现King_admin分页页数————————
#处理def table_data_list(request,app_name,model_name):里的内容,
def filter_querysets(request,queryset):
condtions = {} #定义一个字典用来存过滤的条件
for k,v in request.GET.items():#不需要空的,判断是否为空
# ————————18PerfectCRM实现King_admin搜索关键字————————
# ————————17PerfectCRM实现King_admin单列排序————————
# if k=="page":continue##kingadmin分页功能 # if k=="page":continue##kingadmin分页功能 #写法一
# elif k=="_o":continue##kingadmin排序功能 <a href="?_o={{ column }}">{{ column }}</a> # if k in ("page","_o") :continue #kingadmin分页功能 #kingadmin排序功能 #写法二 # if k == "page"or k == "_o": #保留的分页关键字 和 排序关键字 #写法三
# continue #continue是结束单次循环
# ————————17PerfectCRM实现King_admin单列排序————————
if k in ("page", "_o", "_q"): continue # kingadmin分页,排序,搜索#判断标签是否存在 自定义的名称
# ————————18PerfectCRM实现King_admin搜索关键字———————— # ————————15PerfectCRM实现King_admin多条件过滤————————
if v:
condtions[k] = v #进行配对字典
# ————————15PerfectCRM实现King_admin多条件过滤————————
query_res = queryset.filter(**condtions) return query_res,condtions
# ————————13PerfectCRM实现King_admin分页页数———————— # ————————08PerfectCRM实现King_admin显示注册表的字段表头————————
def table_data_list(request,app_name,model_name):
#通过2个参数到base_admin里获取class AdminRegisterException(Exception): 的对象
admin_obj = base_admin.site.registered_sites[app_name][model_name] #base_admin # ————————24PerfectCRM实现King_admin自定义操作数据————————
if request.method == "POST":#批量操作
action = request.POST.get("action_select")#要调用的自定制功能函数
selected_ids = request.POST.get("selected_ids")#前端提交的数据
print(selected_ids,type(selected_ids),"selected_ids-----")
#if type(selected_ids)!='str':
#selected_ids = json.loads(selected_ids)#进行转换数据
print(selected_ids,type(action),action,"selected_ids==========")
#print("action:",selected_ids,action)
if selected_ids :
#selected_ids = json.loads(selected_ids)#进行转换数据
selected_objs = admin_obj.model.objects.filter(id__in=selected_ids.split(','))#返回之前所选中的条件
else:
raise KeyError('错误,没有选择对象!') if hasattr(admin_obj,action):
action_func = getattr(admin_obj,action)#如果admin_obj 对象中有属性action 则打印self.action的值,否则打印'not find'
request._admin_action=action#添加action内容
print(request._admin_action,action,'<--------')
return action_func(request,selected_objs)
# ————————24PerfectCRM实现King_admin自定义操作数据———————— # ————————09PerfectCRM实现King_admin显示注册表的内容————————
admin_obj.querysets = admin_obj.model.objects.all()#取数据 传到 前端
# ————————09PerfectCRM实现King_admin显示注册表的内容———————— # ————————11PerfectCRM实现King_admin分页显示条数————————
# from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger # 分页功能#放在顶上导入
obj_list = admin_obj.model.objects.all()#取数据 传到 前端 #base_admin #获取传过来的所有对象 # ————————13PerfectCRM实现King_admin分页页数————————
queryset, condtions = filter_querysets(request, obj_list) #base_admin # 调用条件过滤
# ————————13PerfectCRM实现King_admin分页页数———————— # ————————18PerfectCRM实现King_admin搜索关键字————————
queryset = get_queryset_search_result(request,queryset,admin_obj)##搜索后
# ————————18PerfectCRM实现King_admin搜索关键字———————— # ————————26PerfectCRM实现King_admin自定义排序————————
sorted_queryset = get_orderby(request, queryset,admin_obj) #排序后的结果
# ————————17PerfectCRM实现King_admin单列排序————————
# sorted_queryset = get_orderby(request, queryset) #排序后的结果
# ————————15PerfectCRM实现King_admin多条件过滤————————
# paginator = Paginator(obj_list,admin_obj.list_per_page) #kingadmin里class CustomerAdmin(BaseAdmin):
# paginator = Paginator(queryset, admin_obj.list_per_page)
# ————————15PerfectCRM实现King_admin多条件过滤————————
paginator = Paginator(sorted_queryset, admin_obj.list_per_page)
# ————————17PerfectCRM实现King_admin单列排序————————
# ————————26PerfectCRM实现King_admin自定义排序———————— page = request.GET.get('page')
try:
objs = paginator.page(page) # 当前的页面的数据
except PageNotAnInteger:
# 如果页面不是一个整数,交付第一页。
objs = paginator.page(1)
except EmptyPage:
# 如果页面的范围(例如9999),交付最后一页的搜索结果。
objs = paginator.page(paginator.num_pages)
admin_obj.querysets = objs # base_admin # ————————13PerfectCRM实现King_admin分页页数————————
admin_obj.filter_condtions = condtions # base_admin
# ————————13PerfectCRM实现King_admin分页页数———————— # ————————11PerfectCRM实现King_admin分页显示条数———————— return render(request,"king_admin/table_data_list.html",locals())
# ————————08PerfectCRM实现King_admin显示注册表的字段表头———————— # ————————17PerfectCRM实现King_admin单列排序————————
# def get_orderby(request,queryset):
# order_by_key = request.GET.get("_o") #获取URL里有没有("_o") <a href="?_o={{ column }}">{{ column }}</a>
# #页面刚开始没有这个值
# if order_by_key != None: #有("_o")这个值 就进行排序
# query_res = queryset.order_by(order_by_key)
# else: #没有就不排序,直接返回
# query_res = queryset
# return query_res #排序时会错 # orderby_key = request.GET.get("_o")
# if orderby_key:
# return queryset.order_by(orderby_key)
# return queryset #在table_data_list添加
# def table_data_list(request,app_name,model_name): #详细列表
# sorted_queryset = get_orderby(request, queryset)
#在filter_querysets添加
#if k == "page"or k == "_o": #保留的分页关键字 和 排序关键字
# ————————17PerfectCRM实现King_admin单列排序———————— # ————————26PerfectCRM实现King_admin自定义排序————————
def get_orderby(request, queryset, admin_obj):
orderby_key = request.GET.get("_o")
#order_by_key1=order_by_key.strip()
if orderby_key: #有获取到字段
query_res = queryset.order_by(orderby_key.strip()) #.strip()默认删除空白符(包括'\n', '\r', '\t', ' ')
else:
if admin_obj.ordering: #查看kingadmin‘有没有 ordering = '-qq' # 自定义排序
query_res = queryset.order_by("%s" %admin_obj.ordering)
else:
query_res = queryset.order_by('-id') #默认倒序
return query_res #在table_data_list添加
# def table_data_list(request,app_name,model_name): #详细列表
# sorted_queryset = get_orderby(request, queryset, admin_obj) # 排序后的结果
# ————————26PerfectCRM实现King_admin自定义排序———————— # ————————18PerfectCRM实现King_admin搜索关键字————————
from django.db.models import Q
def get_queryset_search_result(request,queryset,admin_obj):
search_key = request.GET.get("_q", "")#取定义名,默认为空
q_obj = Q()#多条件搜索 #from django.db.models import Q
q_obj.connector = "OR" # or/或 条件
for column in admin_obj.search_fields: #搜索目标crm/kingadmin里class CustomerAdmin(BaseAdmin):search_fields = ('name','qq',)
q_obj.children.append(("%s__contains" % column, search_key)) #运态添加多个条件
res = queryset.filter(q_obj) #对数据库进行条件搜索
return res #返回结果
#在table_data_list添加
#def table_data_list(request,app_name,model_name): #详细列表
# queryset = get_queryset_search_result(request,queryset,admin_obj)
# ————————18PerfectCRM实现King_admin搜索关键字———————— # ————————19PerfectCRM实现King_admin数据修改————————
from king_admin import forms
#修改内容
# def table_change(request,app_name,model_name):
# obj_form = forms.CustomerModelForm() #创建一个空表单
# return render(request,"kingadmin/table_change.html",locals()) def table_change(request,app_name,model_name,obj_id):
admin_obj = base_admin.site.registered_sites[app_name][model_name] #获取表对象
#kingadmin/forms.py里def CreateModelForm(request,admin_obj):
model_form = forms.CreateModelForm(request,admin_obj=admin_obj) ##modelform 生成表单 加验证
# obj_form = model_form() # 表单
obj = admin_obj.model.objects.get(id=obj_id)#根据ID获取数据记录 # ————————28PerfectCRM实现King_admin编辑限制————————
# ————————20PerfectCRM实现King_admin数据修改美化————————
# #面向对象最重要的概念就是类(Class)和实例(Instance),必须牢记类是抽象的模板,比如Student类,而实例是根据类创建出来的一个个具体的“对象”,每个对象都拥有相同的方法,但各自的数据可能不同。
# obj_form = model_form(instance=obj) # 数据传入表单 if request.method == "GET":#如果是 GET 表示 是添加记录
obj_form = model_form(instance=obj)#数据传入表单
elif request.method == "POST":#如果是 POST 表示 是修改后的数据
obj_form = model_form(instance=obj,data=request.POST)#更新数据
if obj_form.is_valid():
obj_form.save()
# ————————20PerfectCRM实现King_admin数据修改美化————————
# ————————28PerfectCRM实现King_admin编辑限制———————— return render(request,"king_admin/table_change.html",locals())
# ————————19PerfectCRM实现King_admin数据修改———————— # ————————21PerfectCRM实现King_admin查看页面美化————————
#单个具体app页面
def table_index(request,app_name):
bases=base_admin.site.registered_sites[app_name]#取出对应app对象
return render(request, 'king_admin/table_index.html', {"site":bases,'app_name':app_name})
# ————————21PerfectCRM实现King_admin查看页面美化———————— # ————————22PerfectCRM实现King_admin数据添加————————
from django.shortcuts import redirect # kingadmin添加内容
def table_add(request,app_name,model_name):
admin_obj = base_admin.site.registered_sites[app_name][model_name] #获取表对象 # ————————32PerfectCRM实现King_admin添加不进行限制————————
admin_obj.is_add_form=True#表示为新增表单
# ————————32PerfectCRM实现King_admin添加不进行限制———————— model_form = forms.CreateModelForm(request,admin_obj=admin_obj) ##modelform 生成表单 加验证 if request.method == "GET":
obj_form = model_form() #跳转过来的为空 elif request.method == "POST":
obj_form = model_form(data=request.POST) #创建数据
if obj_form.is_valid():
# ————————32PerfectCRM实现King_admin添加不进行限制————————
# obj_form.save()
try:
obj_form.save()#表单验证通过保存
except Exception as e:
return redirect("/king_admin/%s/%s/" % (app_name,model_name))#转到之前的页面
# ————————32PerfectCRM实现King_admin添加不进行限制————————
if not obj_form.errors: #没有错误返回原来的页面
#from django.shortcuts import redirect
return redirect("/king_admin/%s/%s/" % (app_name,model_name))
return render(request, "king_admin/table_add.html", locals()) # ————————22PerfectCRM实现King_admin数据添加———————— # ————————23PerfectCRM实现King_admin数据删除————————
def table_delete(request,app_name,model_name,obj_id):
admin_obj = base_admin.site.registered_sites[app_name][model_name]#表类
objs=admin_obj.model.objects.filter(id=obj_id)#类的对象
if request.method=='POST':
objs.delete()#删除
return redirect("/king_admin/%s/%s/" % (app_name,model_name))#转到列表页面
return render(request, "king_admin/table_delete.html", locals())#locals 返回一个包含当前范围的局部变量字典。
# ————————23PerfectCRM实现King_admin数据删除————————

#views

 {#table_change.html#}
{## ————————19PerfectCRM实现King_admin数据修改————————#}
{#{% extends "king_master/king_index.html" %}#}
{##}
{#{% load kingadmin_tags %}#}
{#{% block right-container-content %}#}
{##}
{# {{ obj_form }}#}
{##}
{#{% endblock %}#}
{## ————————19PerfectCRM实现King_admin数据修改————————#} {## ————————20PerfectCRM实现King_admin数据修改美化————————#}
{% extends 'king_master/king_index.html' %} {#继承模板#}
{% load kingadmin_tags %} {#通过自己定义标签获取中文,Django中利用filter与simple_tag为前端自定义函数的实现方法#} {% block right-container-content %}
<div class="row" style="margin-bottom: 20px" >
<ol class="breadcrumb">
<li><a href="/king_admin/">主页</a></li>
<li><a href="/king_admin/{% get_app_name admin_obj.model %}/">{% get_app_name admin_obj.model %}</a></li>
<li><a href="/king_admin/{% get_app_name admin_obj.model %}/{% get_model_name admin_obj.model %}/">
{% get_model_verbose_name admin_obj.model%} </a></li>
{% if not admin_obj.is_add_form %} {# 新建时 ForeignKey不能实例化 #}
<li class="active">{{ obj_form.instance }}</li> {# 修改时 实例化 #}
{% endif %}
</ol>
{## ————————25PerfectCRM实现King_admin添加出错修复————————#}
{# <h4>修改:{% get_model_verbose_name admin_obj.model %}</h4>#} {% block Tops %}
<div class="panel panel-info">
<h4 style='color: red'>修改: {% get_model_verbose_name admin_obj.model %}</h4>
</div>
{% endblock %}
{## ————————25PerfectCRM实现King_admin添加出错修复————————#}
</div> <div class="row">
{{ obj_form.errors }} {## ————————28PerfectCRM实现King_admin编辑限制————————#}
{## ————————27PerfectCRM实现King_admin编辑复选框————————#}
{#<form class="form-horizontal" method="post" >{% csrf_token %}#}
<form class="form-horizontal" method="post" onsubmit="return BeforeFormSubmit(this);">{% csrf_token %}
{## ————————27PerfectCRM实现King_admin编辑复选框————————#}
{## ————————28PerfectCRM实现King_admin编辑限制————————#} {% for field in obj_form %}
<div class="form-group">
<label class="col-sm-2 " style="font-weight: normal"> {#字体#}
{% if field.field.required %} {#required判断是不是必须填写#}
<b>{{ field.label }}</b>
{% else %}
{{ field.label }}
{% endif %} </label>
<div class="col-sm-10" >
<span style="color: red;">{{ field.errors }}</span> {## ————————27PerfectCRM实现King_admin编辑复选框————————#}
{# {{ field }}#}
{% if field.name in admin_obj.filter_horizontal %} <!-- 水平--><!-- 判断是否复选框-->
{% get_m2m_chosen_objs admin_obj field.name obj_form.instance as m2m_chosen_objs %} <!--当前对象已经选中的字段名-->
<!-- 左边待选框-->
<div class="col-md-6">
<!-- 取所有的内容-->
{% get_m2m_available_objs admin_obj field.name as m2m_available_objs %}
{# <input type="text" oninput="FuzzSearch(this,'id_{{ field.name }}_from')" class="form-control">#}
<!-- 字段名-->
<select multiple field_name="{{ field.name }}" class="form-control filter-select-box" id="id_{{ field.name }}_from" >
<!-- 字段名 是否为不能修改--> {## ————————32PerfectCRM实现King_admin添加不进行限制————————#}
{## ————————31PerfectCRM实现King_admin编辑多对多限制————————#}
{% if field.name in admin_obj.readonly_fields and not admin_obj.is_add_form %}
{% for obj in m2m_available_objs %}
{% if obj not in m2m_chosen_objs %}<!--不在当象已经选中的字段名 才显示-->
<option value="{{ obj.id }}" disabled>{{ obj }}</option>
{% endif %}
{% endfor %}
{## ————————31PerfectCRM实现King_admin编辑多对多限制————————#}
{## ————————32PerfectCRM实现King_admin添加不进行限制————————#} {% else %}
{% for obj in m2m_available_objs %}
{% if obj not in m2m_chosen_objs %}<!--不在当象已经选中的字段名 才显示-->
<option value="{{ obj.id }}" ondblclick="MoveEleTo(this,'id_{{ field.name }}_to')">{{ obj }}</option>
{% endif %}
{% endfor %}
{% endif %}
</select>
</div>
<!-- 中间箭头-->
<div class="col-md-1">
<div><h4 style='color: #00ff06'>待选 -> </h4></div>
<div><h4 style='color: #8dffc5'>双击选择 </h4></div>
<div><h4 style='color: #ff0003'> <- 已选 </h4></div>
</div> <!-- 右边已选框-->
<div class="col-md-5">
<select m2m_right="yes" name="{{ field.name }}" multiple field_name="{{ field.name }}" class="form-control" id="id_{{ field.name }}_to"> {## ————————32PerfectCRM实现King_admin添加不进行限制————————#}
{## ————————31PerfectCRM实现King_admin编辑多对多限制————————#}
{% if field.name in admin_obj.readonly_fields and not admin_obj.is_add_form %}
{% for obj in m2m_chosen_objs %}
<option value="{{ obj.id }}" disabled>{{ obj }}</option>
{% endfor %}
{## ————————31PerfectCRM实现King_admin编辑多对多限制————————#}
{## ————————32PerfectCRM实现King_admin添加不进行限制————————#} {% else %} {% for obj in m2m_chosen_objs %}
<option value="{{ obj.id }}" ondblclick="MoveEleTo(this,'id_{{ field.name }}_from')">{{ obj }}</option>
{% endfor %}
{% endif %}
</select> </div> {% else %} {## ————————30PerfectCRM实现King_admin编辑自定义字段验证————————#}
{{ field }} <span style="color: #bce8f1"> {{ field.help_text }}</span>
{# <span style="color:red">{{ field.errors }}</span>#}
{## ————————30PerfectCRM实现King_admin编辑自定义字段验证————————#} {% endif %} <!-- 判断是否复选框-->
{## ————————27PerfectCRM实现King_admin编辑复选框————————#} </div>
</div>
{% endfor %} {## ————————25PerfectCRM实现King_admin添加出错修复————————#}
{## ————————23PerfectCRM实现King_admin数据删除————————#}
{# <a class="btn btn-danger" href="{% url 'table_delete' app_name model_name obj_form.instance.id %}">删除</a>#}
{## ————————23PerfectCRM实现King_admin数据删除————————#}
{# <input type="submit" value="保存" class="pull-right btn btn-info" > {#放右边#} <div class="form-group">
{% block del %}
<div class="col-sm-2">
<a class="btn btn-danger" href="{% url 'table_delete' app_name model_name obj_form.instance.id %}">删除</a>
</div>
{% endblock %}
<div class="col-sm-10">
<input type="submit" value="保存" class="pull-right btn btn-info">
</div>
</div>
{## ————————25PerfectCRM实现King_admin添加出错修复————————#} </form>
</div> {% endblock %}
{## ————————20PerfectCRM实现King_admin数据修改美化————————#}

{#table_change.html#}

Django项目:CRM(客户关系管理系统)--40--32PerfectCRM实现King_admin添加不进行限制的更多相关文章

  1. Django CRM客户关系管理系统

    CRM需求分析 随着信息化时代带来的科技创新,CRM客户关系管理系统带来的效益在已经成为很多企业提高竞争优势的一分部,CRM客户关系管理系统将企业管理和客户关系管理集成到统一的平台,其系统功能主要体现 ...

  2. Django项目:CRM(客户关系管理系统)--84--74PerfectCRM实现CRM权限和权限组限制访问URL

    #models.py # ————————01PerfectCRM基本配置ADMIN———————— from django.db import models # Create your models ...

  3. Django项目:CRM(客户关系管理系统)--85--75PerfectCRM实现CRM扩展权限

    # sales_urls.py # ————————47PerfectCRM实现CRM客户报名流程———————— from django.conf.urls import url from bpm. ...

  4. Django项目:CRM(客户关系管理系统)--82--72PerfectCRM实现CRM动态菜单和角色

    #models.py # ————————01PerfectCRM基本配置ADMIN———————— from django.db import models # Create your models ...

  5. Django项目:CRM(客户关系管理系统)--69--59PerfectCRM实现king_admin行内编辑

    #base_admin.py # ————————24PerfectCRM实现King_admin自定义操作数据———————— from django.shortcuts import render ...

  6. Django项目:CRM(客户关系管理系统)--44--36PerfectCRM实现King_admin密码修改

    # king_urls.py # ————————02PerfectCRM创建ADMIN页面———————— from django.conf.urls import url from king_ad ...

  7. Django项目:CRM(客户关系管理系统)--41--33PerfectCRM实现King_admin编辑整张表限制

    readonly_table=False#默认表单不锁定 readonly_table=True#默认表单不锁定 # forms.py # ————————19PerfectCRM实现King_adm ...

  8. Django项目:CRM(客户关系管理系统)--72--62PerfectCRM实现CRM讲师讲课记录

    #urls.py """PerfectCRM URL Configuration The `urlpatterns` list routes URLs to views. ...

  9. Django项目:CRM(客户关系管理系统)--68--58PerfectCRM实现king_admin批量生成上课记录

    # kingadmin.py # ————————04PerfectCRM实现King_admin注册功能———————— from crm import models #print("ki ...

  10. Django项目:CRM(客户关系管理系统)--55--46PerfectCRM实现登陆后页面才能访问

    #urls.py """PerfectCRM URL Configuration The `urlpatterns` list routes URLs to views. ...

随机推荐

  1. more 和less 命令简单介绍以及使用

    一.more命令 more功能类似 cat ,cat命令是整个文件的内容从上到下显示在屏幕上. more会以一页一页的显示方便使用者逐页阅读,而最基本的指令就是按空白键(space)就往下一页显示,按 ...

  2. 解决Mysql因内存不足启动失败的问题

    参考:https://www.jb51.net/article/136432.htm 一.查看内存 free -h free -m 二.解决方法: 1.增加swap交换空间解决问题: dd if=/d ...

  3. vue中使用动画vue-particles实现背景粒子酷炫效果

    先来看我做的效果 我这个是用的背景色加上这个粒子效果实现的demo 平时我们做项目的话会添加背景图片这些,可能更加好看 看我的实现步骤 cnpm install -g vue-cli vue init ...

  4. mybatis结果封装到hashmap中没有null的数据

    1.在ssm框架中 在mybatis-config.xml配置文件中加下面这句代码即可解决 <setting name="callSettersOnNulls" value= ...

  5. hp笔记本在设置VT-x为启用模式后还是无法在VMware上开启CentOS虚拟机

    在h笔记本上,将VT-x设置为Enabled模式后,需要断开电源,拆下电池,然后再按住开机按钮10秒钟左右放开,再重新装上电池,接通电源即可.

  6. VMware的下载安装

    在学习使用LINNX系统之前,先在自己的电脑上安装一个虚拟机,流行的虚拟机软件有VMware(VMWare ACE).Virtual Box和Virtual PC,它们都能在Windows系统上虚拟出 ...

  7. CF402D 【Upgrading Array】

    题目链接: CF402D 题目分析: 首先考虑一下怎么求每个数的分数.把每个数分解到最后会发现它的坏质因子对它分数的贡献是\(-1\),好质因子对它分数的贡献是\(1\),那么最后的分数就是好质因数- ...

  8. MUI离线原生打包,利用Android Studio进行原生打包MUI项目

    首先从官网http://www.dcloud.io/ 下载HBuilder,用该软件创建一个HTML5的移动APP项目,具体可去官网查看相应的文档. 接下来就是如何将写好的HBuilder引入到我们的 ...

  9. <数据链接>常用网站收集

    1.互联网数据指数 百度指数:http://index.baidu.com/ 阿里指数:http://index.1688.com/ TBI腾讯浏览指数:http://tbi.tencent.com/ ...

  10. Windows API 第21篇 DeleteVolumeMountPoint 删除挂载点

    函数原型:BOOL DeleteVolumeMountPoint(                                                      LPCTSTR lpszV ...