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

  1 # forms.py
  2 # ————————19PerfectCRM实现King_admin数据修改————————
  3 from django import forms
  4 from crm import models
  5
  6 # class CustomerModelForm(forms.ModelForm):
  7 #     class Meta: #调用内置方法
  8 #         model = models.Customer  #获取表名
  9 #         fields = "__all__"   #字段
 10
 11 # ————————32PerfectCRM实现King_admin添加不进行限制————————
 12 def CreateModelForm(request,admin_obj): # 添加不进行限制到views里处理
 13 # ————————32PerfectCRM实现King_admin添加不进行限制————————
 14
 15     class Meta: #调用内置方法
 16         model = admin_obj.model  #获取表名
 17         fields = "__all__"   #字段
 18
 19
 20
 21     # ————————20PerfectCRM实现King_admin数据修改美化————————
 22         # type()就是一个最实用又简单的查看数据类型的方法。type()是一个内建的函数,调用它就能够得到一个反回值,从而知道想要查询的对像类型信息。
 23         # dynamic_model_form = type("DynamicModelForm", (forms.ModelForm,), {"Meta": Meta})  #生成modelform的类,
 24     # new()方法是在类准备将自身实例化时调用。new()方法始终都是类的静态方法,即使没有被加上静态方法装饰器。
 25     def __new__(cls, *args, **kwargs):#重写 函数生成方法
 26         # print("base fields",cls.base_fields)
 27         # 字段名    #字段数据
 28         for field_name, field_obj in cls.base_fields.items():
 29             # print(field_name,dir(field_obj))
 30             field_obj.widget.attrs[‘class‘] = ‘form-control‘  # 前端的样式
 31             # field_obj.widget.attrs[‘maxlength‘] = getattr(field_obj,‘max_length‘ ) if hasattr(field_obj,‘max_length‘) \
 32             #     else ""
 33
 34             # ————————32PerfectCRM实现King_admin添加不进行限制————————
 35             if not hasattr(admin_obj, "is_add_form"):  # 如果不是为新增表单
 36             # ————————28PerfectCRM实现King_admin编辑限制————————
 37                 if field_name in admin_obj.readonly_fields:#如果,在
 38                     field_obj.widget.attrs[‘disabled‘] = True
 39             # ————————28PerfectCRM实现King_admin编辑限制————————
 40             # ————————32PerfectCRM实现King_admin添加不进行限制————————
 41
 42         return forms.ModelForm.__new__(cls)
 43
 44     # ————————28PerfectCRM实现King_admin编辑限制————————
 45     def default_clean(self):
 46         #给所有的form默认加一个 clean  验证
 47
 48         # ————————29PerfectCRM实现King_admin编辑自定义限制————————
 49         from django.forms import ValidationError
 50         error_list = []
 51         # ————————29PerfectCRM实现King_admin编辑自定义限制————————
 52
 53         # ————————30PerfectCRM实现King_admin编辑自定义字段验证————————
 54
 55         # ————————32PerfectCRM实现King_admin添加不进行限制————————
 56         if self.instance.id:  # 表示为修改表单
 57         # ————————32PerfectCRM实现King_admin添加不进行限制————————
 58
 59             for field in admin_obj.readonly_fields:  # 如果是不可修改的字段
 60                 # print("readonly",field,self.instance)
 61                 # field_val_from_db = getattr(self.instance,field)#取数据库中的值
 62                 field_val_from_db = getattr(self.instance, field)  # 取数据库中的值
 63                 field_val = self.cleaned_data.get(field)  # 前端传来的值
 64
 65                 # ————————31PerfectCRM实现King_admin编辑多对多限制————————
 66                 if hasattr(field_val_from_db,‘select_related‘):#多对多
 67                     m2m_objs=getattr(field_val_from_db,‘select_related‘)().select_related()#调用多对多,获取对应的值
 68                     m2m_vals=[i[0] for i in m2m_objs.values_list(‘id‘)]#转为列表
 69                     set_m2m_vals=set(m2m_vals)#转集合  交集 数据库
 70
 71                     # vals_from_frontend=self.cleaned_data.get(field)#前端的值  交集
 72                     # m2m_vals=[i[0] for i in vals_from_frontend.values_list(‘id‘)]#转为列表
 73                     # print(vals_from_frontend,‘前端的值  交集‘,m2m_vals)
 74
 75                     set_m2m_vals_from_frontend=set([i.id for i in self.cleaned_data.get(field)])#前端的值  交集
 76                     from django.utils.translation import ugettext as _  # 国际化
 77                     if set_m2m_vals != set_m2m_vals_from_frontend:
 78                         error_list.append(ValidationError(
 79                             _("%(field)s: 该字段不可修改!"),
 80                                     code=‘invalid‘,
 81                                     params={‘field‘:field,}
 82                         ))
 83                         self.add_error(field,"不可修改!")
 84                     continue
 85
 86                 #field_val = self.cleaned_data.get(field)#前端传来的值
 87                 #print(‘field_val‘,type(field_val))
 88                 if field_val_from_db != field_val:
 89                     print("field not change ")#不一致
 90                     error_list.append(ValidationError(#添加错误信息
 91                                     _("该字段%(field)s 不可修改,原值为: %(val)s"),
 92                                     code=‘invalid‘,
 93                                     params={‘field‘:field,‘val‘:field_val_from_db}
 94                                 ))
 95
 96                 # else: # 被篡改了
 97                 #     self.add_error(field,‘ "%s" is a readonly field ,value should be "%s" ‘% (field, field_val_from_db))
 98
 99                 # ————————31PerfectCRM实现King_admin编辑多对多限制————————
100
101         #print("cleaned data:",self.cleaned_data,)#要验证的表单
102         for field in self.cleaned_data:#单独字段
103             if hasattr(admin_obj,‘clean_%s‘%field):#是否有该字段的单独验证
104                 field_clean_func=getattr(admin_obj,‘clean_%s‘%field)#获取对应的函数
105                 response=field_clean_func(self)#
106                 if response:
107                     error_list.append(response)
108                 if error_list:
109                     raise ValidationError(error_list)
110                 #response_sol=admin_obj.(‘clean_%s‘%field)(self.cleaned_data)
111         # ————————30PerfectCRM实现King_admin编辑自定义字段验证————————
112
113
114         # ————————31PerfectCRM实现King_admin编辑多对多限制————————
115         # print("default clean:",self)#得到整个form数据
116         # for field in admin_obj.readonly_fields:#循环获取crm/kingadmin.py里    readonly_fields = (‘name‘,‘qq‘,)的数据
117         #     print("readonly",field,self.instance)#获取到 字段名 ,对象(值)
118         #     field_val_from_db  = getattr(self.instance,field)#获取数据库的值
119         #     print("cleaned data:", self.cleaned_data)#获取到 前端的值
120         #     field_val = self.cleaned_data.get(field)#获取到 前端的值
121         #
122         #     if field_val_from_db == field_val:#数据库的值和前端的值对比
123         #         print("数据库数据和前端数据一样 ")
124         #     else: # 被篡改了
125         #         self.add_error(field,‘ "%s" 是一个只读的字段,值应该是 "%s"! 大神请不要篡改!!!‘% (field, field_val_from_db))
126         # ————————31PerfectCRM实现King_admin编辑多对多限制————————
127
128
129         # ————————29PerfectCRM实现King_admin编辑自定义限制————————
130         response=admin_obj.default_form_validation(self)#可自定制
131         if response:
132             error_list.append(response)
133         if error_list:
134             raise ValidationError(error_list)
135         # ————————29PerfectCRM实现King_admin编辑自定义限制————————
136
137     # ————————28PerfectCRM实现King_admin编辑限制————————
138
139     dynamic_model_form = type("DynamicModelForm", (forms.ModelForm,), {"Meta": Meta})  # 生成modelform的类,
140     setattr(dynamic_model_form, "__new__", __new__)
141     # ————————20PerfectCRM实现King_admin数据修改美化————————
142
143     # ————————28PerfectCRM实现King_admin编辑限制————————
144     setattr(dynamic_model_form,"clean",default_clean)  #给所有的form默认加一个 clean  验证
145     # ————————28PerfectCRM实现King_admin编辑限制—————
146
147     return dynamic_model_form
148 # ————————19PerfectCRM实现King_admin数据修改————————

# forms.py

  1 #views
  2
  3 # ————————02PerfectCRM创建ADMIN页面————————
  4 from django.shortcuts import render
  5
  6 # ————————04PerfectCRM实现King_admin注册功能————————
  7 # from django import conf #配置文件
  8 # print("dj conf:",conf) #配置文件
  9 # print("dj conf:",conf.settings)#配置文件.设置
 10 # ————————04PerfectCRM实现King_admin注册功能————————
 11
 12 # ————————04PerfectCRM实现King_admin注册功能————————
 13 from king_admin import app_config #自动调用  动态加载类和函数
 14 # ————————04PerfectCRM实现King_admin注册功能————————
 15
 16 # ————————04PerfectCRM实现King_admin注册功能————————
 17 # from king_admin.base_admin import registered_sites # registered_sites={}
 18 from king_admin import base_admin
 19 # ————————04PerfectCRM实现King_admin注册功能————————
 20
 21 # ————————11PerfectCRM实现King_admin基本分页————————
 22 from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger  # 分页功能
 23 # ————————11PerfectCRM实现King_admin基本分页————————
 24
 25 def app_index(request):
 26     # ————————04PerfectCRM实现King_admin注册功能————————
 27     # for app in conf.settings.INSTALLED_APPS:
 28     #     print(app)#循环打印 配置文件.设置.安装应用程序#.Perfectcustomer\settings里的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
 77     return query_res,condtions
 78 # ————————13PerfectCRM实现King_admin分页页数————————
 79
 80 # ————————08PerfectCRM实现King_admin显示注册表的字段表头————————
 81 def table_data_list(request,app_name,model_name):
 82     #通过2个参数到base_admin里获取class AdminRegisterException(Exception): 的对象
 83     admin_obj = base_admin.site.registered_sites[app_name][model_name]  #base_admin
 84
 85     # ————————24PerfectCRM实现King_admin自定义操作数据————————
 86     if request.method == "POST":#批量操作
 87         action = request.POST.get("action_select")#要调用的自定制功能函数
 88         selected_ids = request.POST.get("selected_ids")#前端提交的数据
 89         print(selected_ids,type(selected_ids),"selected_ids-----")
 90         #if type(selected_ids)!=‘str‘:
 91         #selected_ids = json.loads(selected_ids)#进行转换数据
 92         print(selected_ids,type(action),action,"selected_ids==========")
 93         #print("action:",selected_ids,action)
 94         if selected_ids :
 95             #selected_ids = json.loads(selected_ids)#进行转换数据
 96             selected_objs = admin_obj.model.objects.filter(id__in=selected_ids.split(‘,‘))#返回之前所选中的条件
 97         else:
 98             raise KeyError(‘错误,没有选择对象!‘)
 99
100         if hasattr(admin_obj,action):
101             action_func = getattr(admin_obj,action)#如果admin_obj 对象中有属性action 则打印self.action的值,否则打印‘not find‘
102             request._admin_action=action#添加action内容
103             print(request._admin_action,action,‘<--------‘)
104         return action_func(request,selected_objs)
105     # ————————24PerfectCRM实现King_admin自定义操作数据————————
106
107
108     # ————————09PerfectCRM实现King_admin显示注册表的内容————————
109     admin_obj.querysets =  admin_obj.model.objects.all()#取数据 传到 前端
110     # ————————09PerfectCRM实现King_admin显示注册表的内容————————
111
112     # ————————11PerfectCRM实现King_admin分页显示条数————————
113     # from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger  # 分页功能#放在顶上导入
114     obj_list =  admin_obj.model.objects.all()#取数据 传到 前端  #base_admin  #获取传过来的所有对象
115
116     # ————————13PerfectCRM实现King_admin分页页数————————
117     queryset, condtions = filter_querysets(request, obj_list)  #base_admin   # 调用条件过滤
118     # ————————13PerfectCRM实现King_admin分页页数————————
119
120     # ————————18PerfectCRM实现King_admin搜索关键字————————
121     queryset = get_queryset_search_result(request,queryset,admin_obj)##搜索后
122     # ————————18PerfectCRM实现King_admin搜索关键字————————
123
124     # ————————26PerfectCRM实现King_admin自定义排序————————
125     sorted_queryset = get_orderby(request, queryset,admin_obj) #排序后的结果
126     # ————————17PerfectCRM实现King_admin单列排序————————
127     # sorted_queryset = get_orderby(request, queryset) #排序后的结果
128     # ————————15PerfectCRM实现King_admin多条件过滤————————
129     # paginator = Paginator(obj_list,admin_obj.list_per_page)  #kingadmin里class CustomerAdmin(BaseAdmin):
130     # paginator = Paginator(queryset, admin_obj.list_per_page)
131     # ————————15PerfectCRM实现King_admin多条件过滤————————
132     paginator = Paginator(sorted_queryset, admin_obj.list_per_page)
133     # ————————17PerfectCRM实现King_admin单列排序————————
134     # ————————26PerfectCRM实现King_admin自定义排序————————
135
136
137     page = request.GET.get(‘page‘)
138     try:
139         objs = paginator.page(page)  # 当前的页面的数据
140     except PageNotAnInteger:
141         # 如果页面不是一个整数,交付第一页。
142         objs = paginator.page(1)
143     except EmptyPage:
144         # 如果页面的范围(例如9999),交付最后一页的搜索结果。
145         objs = paginator.page(paginator.num_pages)
146     admin_obj.querysets = objs  # base_admin
147
148     # ————————13PerfectCRM实现King_admin分页页数————————
149     admin_obj.filter_condtions = condtions  # base_admin
150     # ————————13PerfectCRM实现King_admin分页页数————————
151
152     # ————————11PerfectCRM实现King_admin分页显示条数————————
153
154     return render(request,"king_admin/table_data_list.html",locals())
155 # ————————08PerfectCRM实现King_admin显示注册表的字段表头————————
156
157
158
159
160 # ————————17PerfectCRM实现King_admin单列排序————————
161 # def get_orderby(request,queryset):
162     # order_by_key = request.GET.get("_o")   #获取URL里有没有("_o") <a href="?_o={{ column }}">{{ column }}</a>
163     # #页面刚开始没有这个值
164     # if order_by_key != None:  #有("_o")这个值 就进行排序
165     #     query_res = queryset.order_by(order_by_key)
166     # else: #没有就不排序,直接返回
167     #     query_res = queryset
168     # return query_res     #排序时会错
169
170     # orderby_key = request.GET.get("_o")
171     # if orderby_key:
172     #     return  queryset.order_by(orderby_key)
173     # return  queryset
174
175 #在table_data_list添加
176 # def table_data_list(request,app_name,model_name): #详细列表
177 # sorted_queryset = get_orderby(request, queryset)
178 #在filter_querysets添加
179 #if k == "page"or k == "_o": #保留的分页关键字 和  排序关键字
180 # ————————17PerfectCRM实现King_admin单列排序————————
181
182 # ————————26PerfectCRM实现King_admin自定义排序————————
183 def get_orderby(request, queryset, admin_obj):
184     orderby_key = request.GET.get("_o")
185     #order_by_key1=order_by_key.strip()
186     if orderby_key: #有获取到字段
187         query_res = queryset.order_by(orderby_key.strip()) #.strip()默认删除空白符(包括‘\n‘, ‘\r‘,  ‘\t‘,  ‘ ‘)
188     else:
189         if admin_obj.ordering: #查看kingadmin‘有没有    ordering = ‘-qq‘  # 自定义排序
190             query_res = queryset.order_by("%s" %admin_obj.ordering)
191         else:
192             query_res = queryset.order_by(‘-id‘) #默认倒序
193     return query_res
194
195 #在table_data_list添加
196 # def table_data_list(request,app_name,model_name): #详细列表
197 # sorted_queryset = get_orderby(request, queryset, admin_obj)  # 排序后的结果
198 # ————————26PerfectCRM实现King_admin自定义排序————————
199
200
201 # ————————18PerfectCRM实现King_admin搜索关键字————————
202 from django.db.models import Q
203 def get_queryset_search_result(request,queryset,admin_obj):
204     search_key = request.GET.get("_q", "")#取定义名,默认为空
205     q_obj = Q()#多条件搜索 #from django.db.models import Q
206     q_obj.connector = "OR"  # or/或 条件
207     for column in admin_obj.search_fields: #搜索目标crm/kingadmin里class CustomerAdmin(BaseAdmin):search_fields = (‘name‘,‘qq‘,)
208         q_obj.children.append(("%s__contains" % column, search_key)) #运态添加多个条件
209     res = queryset.filter(q_obj) #对数据库进行条件搜索
210     return res   #返回结果
211 #在table_data_list添加
212 #def table_data_list(request,app_name,model_name): #详细列表
213 #      queryset = get_queryset_search_result(request,queryset,admin_obj)
214 # ————————18PerfectCRM实现King_admin搜索关键字————————
215
216 # ————————19PerfectCRM实现King_admin数据修改————————
217 from  king_admin import forms
218 #修改内容
219 # def table_change(request,app_name,model_name):
220 #     obj_form = forms.CustomerModelForm()  #创建一个空表单
221 #     return render(request,"kingadmin/table_change.html",locals())
222
223 def table_change(request,app_name,model_name,obj_id):
224     admin_obj = base_admin.site.registered_sites[app_name][model_name]   #获取表对象
225                 #kingadmin/forms.py里def CreateModelForm(request,admin_obj):
226     model_form = forms.CreateModelForm(request,admin_obj=admin_obj)  ##modelform 生成表单 加验证
227     # obj_form = model_form()  # 表单
228     obj = admin_obj.model.objects.get(id=obj_id)#根据ID获取数据记录
229
230     # ————————28PerfectCRM实现King_admin编辑限制————————
231     # ————————20PerfectCRM实现King_admin数据修改美化————————
232     # #面向对象最重要的概念就是类(Class)和实例(Instance),必须牢记类是抽象的模板,比如Student类,而实例是根据类创建出来的一个个具体的“对象”,每个对象都拥有相同的方法,但各自的数据可能不同。
233     # obj_form = model_form(instance=obj)  # 数据传入表单
234
235     if request.method == "GET":#如果是 GET 表示 是添加记录
236         obj_form = model_form(instance=obj)#数据传入表单
237     elif request.method == "POST":#如果是 POST 表示 是修改后的数据
238         obj_form = model_form(instance=obj,data=request.POST)#更新数据
239         if obj_form.is_valid():
240             obj_form.save()
241     # ————————20PerfectCRM实现King_admin数据修改美化————————
242     # ————————28PerfectCRM实现King_admin编辑限制————————
243
244     return render(request,"king_admin/table_change.html",locals())
245 # ————————19PerfectCRM实现King_admin数据修改————————
246
247 # ————————21PerfectCRM实现King_admin查看页面美化————————
248 #单个具体app页面
249 def table_index(request,app_name):
250     bases=base_admin.site.registered_sites[app_name]#取出对应app对象
251     return render(request, ‘king_admin/table_index.html‘, {"site":bases,‘app_name‘:app_name})
252 # ————————21PerfectCRM实现King_admin查看页面美化————————
253
254
255
256
257
258 # ————————22PerfectCRM实现King_admin数据添加————————
259 from django.shortcuts import redirect  # kingadmin添加内容
260 def table_add(request,app_name,model_name):
261     admin_obj = base_admin.site.registered_sites[app_name][model_name]  #获取表对象
262
263     # ————————32PerfectCRM实现King_admin添加不进行限制————————
264     admin_obj.is_add_form=True#表示为新增表单
265     # ————————32PerfectCRM实现King_admin添加不进行限制————————
266
267     model_form = forms.CreateModelForm(request,admin_obj=admin_obj) ##modelform 生成表单 加验证
268
269     if request.method == "GET":
270         obj_form = model_form() #跳转过来的为空
271
272     elif request.method == "POST":
273         obj_form = model_form(data=request.POST)  #创建数据
274         if obj_form.is_valid():
275             # ————————32PerfectCRM实现King_admin添加不进行限制————————
276             # obj_form.save()
277             try:
278                 obj_form.save()#表单验证通过保存
279             except Exception as e:
280                 return redirect("/king_admin/%s/%s/" % (app_name,model_name))#转到之前的页面
281             # ————————32PerfectCRM实现King_admin添加不进行限制————————
282         if not obj_form.errors:   #没有错误返回原来的页面
283             #from django.shortcuts import redirect
284             return  redirect("/king_admin/%s/%s/" % (app_name,model_name))
285     return render(request, "king_admin/table_add.html", locals())
286
287 # ————————22PerfectCRM实现King_admin数据添加————————
288
289
290 # ————————23PerfectCRM实现King_admin数据删除————————
291 def table_delete(request,app_name,model_name,obj_id):
292     admin_obj = base_admin.site.registered_sites[app_name][model_name]#表类
293     objs=admin_obj.model.objects.get(id=obj_id)#类的对象
294     if request.method==‘POST‘:
295         objs.delete()#删除
296         return redirect("/king_admin/%s/%s/" % (app_name,model_name))#转到列表页面
297     return render(request, "king_admin/table_delete.html", locals())#locals 返回一个包含当前范围的局部变量字典。
298 # ————————23PerfectCRM实现King_admin数据删除————————

#views

  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           <li class="active">{{ obj_form.instance }}</li>
 28         </ol>
 29          {## ————————25PerfectCRM实现King_admin添加出错修复————————#}
 30 {#        <h4>修改:{% get_model_verbose_name admin_obj.model  %}</h4>#}
 31
 32         {% block Tops %}
 33             <div class="panel panel-info">
 34                 <h4 style=‘color: red‘>修改: {% get_model_verbose_name admin_obj.model %}</h4>
 35             </div>
 36         {% endblock %}
 37          {## ————————25PerfectCRM实现King_admin添加出错修复————————#}
 38     </div>
 39
 40    <div class="row">
 41         {{ obj_form.errors  }}
 42
 43         {## ————————28PerfectCRM实现King_admin编辑限制————————#}
 44         {## ————————27PerfectCRM实现King_admin编辑复选框————————#}
 45         {#<form class="form-horizontal" method="post" >{% csrf_token %}#}
 46         <form class="form-horizontal" method="post" onsubmit="return BeforeFormSubmit(this);">{% csrf_token %}
 47         {## ————————27PerfectCRM实现King_admin编辑复选框————————#}
 48         {## ————————28PerfectCRM实现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
 78                                     {## ————————32PerfectCRM实现King_admin添加不进行限制————————#}
 79                                     {## ————————31PerfectCRM实现King_admin编辑多对多限制————————#}
 80                                     {% if field.name in admin_obj.readonly_fields and not admin_obj.is_add_form %}
 81                                         {% for obj in m2m_available_objs  %}
 82                                             {% if obj not in m2m_chosen_objs %}<!--不在当象已经选中的字段名 才显示-->
 83                                                 <option value="{{ obj.id }}" disabled>{{ obj }}</option>
 84                                             {% endif %}
 85                                         {% endfor %}
 86                                     {## ————————31PerfectCRM实现King_admin编辑多对多限制————————#}
 87                                     {## ————————32PerfectCRM实现King_admin添加不进行限制————————#}
 88
 89                                     {% else %}
 90                                         {% for obj in m2m_available_objs %}
 91                                             {% if obj not in m2m_chosen_objs %}<!--不在当象已经选中的字段名 才显示-->
 92                                                 <option value="{{ obj.id }}" ondblclick="MoveEleTo(this,‘id_{{ field.name }}_to‘)">{{ obj }}</option>
 93                                             {% endif %}
 94                                         {% endfor %}
 95                                     {% endif %}
 96                                 </select>
 97                             </div>
 98                             <!--    中间箭头-->
 99                             <div class="col-md-1">
100                                 <div><h4 style=‘color: #00ff06‘>待选 ->  </h4></div>
101                                 <div><h4 style=‘color: #8dffc5‘>双击选择 </h4></div>
102                                 <div><h4 style=‘color: #ff0003‘> <- 已选 </h4></div>
103                             </div>
104
105                             <!--    右边已选框-->
106                             <div class="col-md-5">
107                                 <select m2m_right="yes" name="{{ field.name }}" multiple field_name="{{ field.name }}" class="form-control" id="id_{{ field.name }}_to">
108
109                                      {## ————————32PerfectCRM实现King_admin添加不进行限制————————#}
110                                     {## ————————31PerfectCRM实现King_admin编辑多对多限制————————#}
111                                     {% if field.name in admin_obj.readonly_fields and not admin_obj.is_add_form %}
112                                         {% for obj in m2m_chosen_objs %}
113                                          <option value="{{ obj.id }}" disabled>{{ obj }}</option>
114                                         {% endfor %}
115                                      {## ————————31PerfectCRM实现King_admin编辑多对多限制————————#}
116                                      {## ————————32PerfectCRM实现King_admin添加不进行限制————————#}
117
118                                     {% else %}
119
120                                         {% for obj in m2m_chosen_objs %}
121                                             <option value="{{ obj.id }}" ondblclick="MoveEleTo(this,‘id_{{ field.name }}_from‘)">{{ obj }}</option>
122                                         {% endfor %}
123                                     {% endif %}
124                                 </select>
125
126                             </div>
127
128                         {% else %}
129
130                             {## ————————30PerfectCRM实现King_admin编辑自定义字段验证————————#}
131                             {{ field }} <span style="color: #bce8f1"> {{ field.help_text }}</span>
132 {#                            <span style="color:red">{{ field.errors }}</span>#}
133                             {## ————————30PerfectCRM实现King_admin编辑自定义字段验证————————#}
134
135
136                         {% endif %} <!--     判断是否复选框-->
137                         {## ————————27PerfectCRM实现King_admin编辑复选框————————#}
138
139
140
141                     </div>
142                   </div>
143             {% endfor %}
144
145             {## ————————25PerfectCRM实现King_admin添加出错修复————————#}
146             {## ————————23PerfectCRM实现King_admin数据删除————————#}
147 {#            <a class="btn btn-danger" href="{% url ‘table_delete‘ app_name model_name obj_form.instance.id %}">删除</a>#}
148            {## ————————23PerfectCRM实现King_admin数据删除————————#}
149 {#            <input type="submit" value="保存" class="pull-right btn btn-info" >   {#放右边#}
150
151             <div class="form-group">
152                 {% block del %}
153                     <div class="col-sm-2">
154                         <a class="btn btn-danger" href="{% url ‘table_delete‘ app_name model_name obj_form.instance.id %}">删除</a>
155                     </div>
156                 {% endblock %}
157                 <div class="col-sm-10">
158                     <input type="submit" value="保存" class="pull-right btn btn-info">
159                 </div>
160             </div>
161             {## ————————25PerfectCRM实现King_admin添加出错修复————————#}
162
163         </form>
164    </div>
165
166
167
168
169
170 {% endblock %}
171 {## ————————20PerfectCRM实现King_admin数据修改美化————————#}

{#table_change.html#}

原文地址:https://www.cnblogs.com/ujq3/p/8711497.html

时间: 2024-10-09 06:13:00

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

Django CRM客户关系管理系统

CRM需求分析 随着信息化时代带来的科技创新,CRM客户关系管理系统带来的效益在已经成为很多企业提高竞争优势的一分部,CRM客户关系管理系统将企业管理和客户关系管理集成到统一的平台,其系统功能主要体现在企业与客户之间的业务和企业内部之前部门之间的业务.因此CRM客户关系管理系统不但可以记录企业自内部信息,对于客户信息存储也是可以做到的,其中还涉及市场竞争对手的情报资料,还包括了企业进行营销.销售及支持服务所需的各种数据. 功能实现 (1)建议统一的信息编码系统; (2)设计能够良好反映事物特性的

CRM客户关系管理系统商业项目

本课程共33讲,购买课程后,可以下载项目需求分析文档,数据库设计文档,完整的项目源代码,数据库文件等资料,系统采用jsp,servlet,js,ajax,jquery,easyui,mysql数据库等相关技术实现,所有代码均为原生态,无第三方插件,系统稳定,高效,快捷,本系统是专门针对各种中小型企业量身定做的CRM客户关系管理系统,为企业管客户,管商机,管销售,从而推动业务进展,提高工作效率,管理大数据. 项目主要功能有客户管理,合同管理,合同附件管理,合同预览(放大缩小),订单管理,商务洽谈,

CRM客户关系管理系统商业项目视频课程

本课程共33讲,购买课程后,可以下载项目需求分析文档,数据库设计文档,完整的项目源代码,数据库文件等资料,系统采用jsp,servlet,js,ajax,jquery,easyui,mysql数据库等相关技术实现,所有代码均为原生态,无第三方插件,系统稳定,高效,快捷,本系统是专门针对各种中小型企业量身定做的CRM客户关系管理系统,为企业管客户,管商机,管销售,从而推动业务进展,提高工作效率,管理大数据. 项目主要功能有客户管理,合同管理,合同附件管理,合同预览(放大缩小),订单管理,商务洽谈,

CRM客户关系管理系统需求分析文档

系统简介 本软件采用现在流行的WEB架构开发,主要针对中小型公司.管销售,管客户,管商机:可以在任何能上网的地方登录使用,使用简单,功能强大,方便快捷,丰富完善的报表功能,极大的提高公司的运营效率,不会因为人员的变动而导致数据的丢失,对公司的日常业务,问题追责等提供详细数据,对于公司领导可以做到"一表知天下",具体功能如下:1.客户管理:1.1.有非常完善的客户资料信息,对不同的客户进行分类管理,如普通客户,VIP客户,成交客户和潜在客户等1.2.对客户的每次来电,拜访情况可以做详细的

crm客户关系管理系统大约多少钱?

随着CRM在企业中的应用普遍化,不少人相信对CRM系统并不陌生,但是更多人关注的还是CRM客户关系管理系统价格如何. 其实CRM价格并不是固定的,毕竟市面上CRM系统种类众多,种类不同,价格不一样,功能不同,价格也不一样,所以CRM客户关系管理系统价格是由多方面因素影响的. 其实不同的CRM都有不同的价格,况且现在很多CRM都分模块或分版本销售,所以会出现不同的需求不同的价格.当然了选择CRM不仅仅要看价格,而且要看这套CRM是否符合自己公司的具体需求.可以尝试多去试用,多去对比,找出适合自己企

最好用的CRM客户关系管理系统

佳网CRM客户关系管理系统我们致力于解决企业客户管理,提高企业的办事效率,为企业提供一站式服务化繁为简: 统一管理,不再分散 解决客户资料分散于业务员个人的问题,现在每个人一个帐号,客户资料统一管理 权限设置细化明确 不同部门设置不同的菜单权限,不同的员工级别设置不同的操作权限 精准定位,多条件查找 根据级别.合同状态.所属业务员.跟单状态等不同条件快速查找客户资料 客户资料随身而行 移动端全功能支持,随时随地看客户.跟单.订单.合同资料 实时消息提醒 第一时间通知与您相关的新消息,即刻加入企业

CRM客户关系管理系统如何分析客户的动态需求

由于激烈的市场竞争,对于怎样掌握客户的动态需求,怎样保持客户市场的稳定增长,对于企业来说已经成为普遍的关注点.CRM客户关系管理系统经过了10年的发展历程,怎样管理客户.了解客户成就了CRM客户关系管理系统的大市场. CRM供货商一般侧重于宣扬软件的特性及功用,而对其全体价值则没有做出了解的表述. 用户高档处理层一般从基础设施安顿而非运营和战略视点对待CRM客户关系管理系统施行. 由于无法从运营和战略视点安顿CRM客户关系管理系统,用户对CRM的价值认知只停留在技术功率层面上. 只需跨过技术和流

CRM客户关系管理系统如何推动企业走向成功

随着我国互联网信息技术水平的不断提高,crm客户关系管理系统发展迅速.许多的企业对crm系统进行了引进,帮助企业赢得收益与未来,那crm系统如何帮助企业走向成功的呢?下面我们一起来看看. 一.集中保存客户信息客户无疑是企业发展的根本,crm系统拥有强大的客户信息管理的能力,可以详细记录客户信息,对客户的信息进行集中管理和共享,防止出现因业务调整或人员的流动而产生客户资源或数据的流失:同时,crm系统能够保证客户信息的完整,积累企业的宝贵财富.让企业从现有客户中获取更多市场份额,让客户生命周期发挥

Django项目:CRM(客户关系管理系统)--43--335PerfectCRM实现CRM重写Admin密码修改

1 # king_urls.py 2 # --------02PerfectCRM创建ADMIN页面-------- 3 from django.conf.urls import url 4 from king_admin import views 5 6 urlpatterns = [ 7 url(r'^$', views.app_index),#主页 8 9 # --------21PerfectCRM实现King_admin查看页面美化-------- 10 url(r'^(\w+)/$'