diff --git a/groups/admin.py b/groups/admin.py index 18f51cd9..3e69d267 100644 --- a/groups/admin.py +++ b/groups/admin.py @@ -10,4 +10,11 @@ class GroupAdmin(admin.ModelAdmin): def formfield_for_manytomany(self, db_field, request, **kwargs): if db_field.name == "members": kwargs["queryset"] = s_models.Partment.objects.filter(iscompany=1,deletemark=1) - return super().formfield_for_manytomany(db_field, request, **kwargs) \ No newline at end of file + return super().formfield_for_manytomany(db_field, request, **kwargs) + +@admin.register(models.Groupmember) +class GroupmemberAdmin(admin.ModelAdmin): + def formfield_for_foreignkey(self, db_field, request, **kwargs): + if db_field.name == "member": + kwargs["queryset"] = s_models.Partment.objects.filter(iscompany=1,deletemark=1) + return super().formfield_for_foreignkey(db_field, request, **kwargs) \ No newline at end of file diff --git a/groups/migrations/0003_auto_20191024_1056.py b/groups/migrations/0003_auto_20191024_1056.py new file mode 100644 index 00000000..7b723403 --- /dev/null +++ b/groups/migrations/0003_auto_20191024_1056.py @@ -0,0 +1,31 @@ +# Generated by Django 2.1.5 on 2019-10-24 10:56 + +from django.db import migrations, models +import django.db.models.deletion + + +class Migration(migrations.Migration): + + dependencies = [ + ('safesite', '0281_remove_companyinfo_liaison_fax'), + ('groups', '0002_auto_20191017_0929'), + ] + + operations = [ + migrations.CreateModel( + name='Groupmember', + fields=[ + ('id', models.AutoField(auto_created=True, primary_key=True, serialize=False, verbose_name='ID')), + ], + ), + migrations.AddField( + model_name='groupmember', + name='group', + field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='groups.Group'), + ), + migrations.AddField( + model_name='groupmember', + name='member', + field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to='safesite.Partment'), + ), + ] diff --git a/groups/migrations/0004_auto_20191024_1109.py b/groups/migrations/0004_auto_20191024_1109.py new file mode 100644 index 00000000..4f15b44a --- /dev/null +++ b/groups/migrations/0004_auto_20191024_1109.py @@ -0,0 +1,18 @@ +# Generated by Django 2.1.5 on 2019-10-24 11:09 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('groups', '0003_auto_20191024_1056'), + ] + + operations = [ + migrations.RenameField( + model_name='group', + old_name='members', + new_name='member', + ), + ] diff --git a/groups/migrations/0005_remove_group_member.py b/groups/migrations/0005_remove_group_member.py new file mode 100644 index 00000000..d72f809e --- /dev/null +++ b/groups/migrations/0005_remove_group_member.py @@ -0,0 +1,17 @@ +# Generated by Django 2.1.5 on 2019-10-24 11:11 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('groups', '0004_auto_20191024_1109'), + ] + + operations = [ + migrations.RemoveField( + model_name='group', + name='member', + ), + ] diff --git a/groups/migrations/0006_group_members.py b/groups/migrations/0006_group_members.py new file mode 100644 index 00000000..6076ee27 --- /dev/null +++ b/groups/migrations/0006_group_members.py @@ -0,0 +1,19 @@ +# Generated by Django 2.1.5 on 2019-10-24 11:20 + +from django.db import migrations, models + + +class Migration(migrations.Migration): + + dependencies = [ + ('safesite', '0285_remove_companyinfo_liaison_fax'), + ('groups', '0005_remove_group_member'), + ] + + operations = [ + migrations.AddField( + model_name='group', + name='members', + field=models.ManyToManyField(through='groups.Groupmember', to='safesite.Partment'), + ), + ] diff --git a/groups/models.py b/groups/models.py index 64459f5f..01689d7c 100644 --- a/groups/models.py +++ b/groups/models.py @@ -11,8 +11,7 @@ class Group(models.Model): groupname = models.CharField(max_length=128, unique=True) type = models.CharField(max_length=32, choices=grouptype, default="集团") createtime = models.DateTimeField(auto_now_add=True) - members = models.ManyToManyField(s_models.Partment) - + members = models.ManyToManyField(s_models.Partment,through='Groupmember') def __str__(self): return self.groupname @@ -21,6 +20,10 @@ class Group(models.Model): verbose_name="集团" verbose_name_plural="集团" +class Groupmember(models.Model): + group = models.ForeignKey(Group,on_delete=models.CASCADE) + member = models.ForeignKey(s_models.Partment,on_delete=models.CASCADE) + class GroupUser(models.Model): username = models.CharField(max_length=128, unique=True) password = models.CharField(max_length=256) diff --git a/groups/static/groups/time/laydate/laydate.js b/groups/static/groups/time/laydate/laydate.js new file mode 100644 index 00000000..83a12cbe --- /dev/null +++ b/groups/static/groups/time/laydate/laydate.js @@ -0,0 +1,2 @@ +/*! laydate-v5.0.9 日期与时间组件 MIT License http://www.layui.com/laydate/ By 贤心 */ + ;!function(){"use strict";var e=window.layui&&layui.define,t={getPath:function(){var e=document.currentScript?document.currentScript.src:function(){for(var e,t=document.scripts,n=t.length-1,a=n;a>0;a--)if("interactive"===t[a].readyState){e=t[a].src;break}return e||t[n].src}();return e.substring(0,e.lastIndexOf("/")+1)}(),getStyle:function(e,t){var n=e.currentStyle?e.currentStyle:window.getComputedStyle(e,null);return n[n.getPropertyValue?"getPropertyValue":"getAttribute"](t)},link:function(e,a,i){if(n.path){var r=document.getElementsByTagName("head")[0],o=document.createElement("link");"string"==typeof a&&(i=a);var s=(i||e).replace(/\.|\//g,""),l="layuicss-"+s,d=0;o.rel="stylesheet",o.href=n.path+e,o.id=l,document.getElementById(l)||r.appendChild(o),"function"==typeof a&&!function c(){return++d>80?window.console&&console.error("laydate.css: Invalid"):void(1989===parseInt(t.getStyle(document.getElementById(l),"width"))?a():setTimeout(c,100))}()}}},n={v:"5.0.9",config:{},index:window.laydate&&window.laydate.v?1e5:0,path:t.getPath,set:function(e){var t=this;return t.config=w.extend({},t.config,e),t},ready:function(a){var i="laydate",r="",o=(e?"modules/laydate/":"theme/")+"default/laydate.css?v="+n.v+r;return e?layui.addcss(o,a,i):t.link(o,a,i),this}},a=function(){var e=this;return{hint:function(t){e.hint.call(e,t)},config:e.config}},i="laydate",r=".layui-laydate",o="layui-this",s="laydate-disabled",l="开始日期超出了结束日期
建议重新选择",d=[100,2e5],c="layui-laydate-static",m="layui-laydate-list",u="laydate-selected",h="layui-laydate-hint",y="laydate-day-prev",f="laydate-day-next",p="layui-laydate-footer",g=".laydate-btns-confirm",v="laydate-time-text",D=".laydate-btns-time",T=function(e){var t=this;t.index=++n.index,t.config=w.extend({},t.config,n.config,e),n.ready(function(){t.init()})},w=function(e){return new C(e)},C=function(e){for(var t=0,n="object"==typeof e?[e]:(this.selector=e,document.querySelectorAll(e||null));t0)return n[0].getAttribute(e)}():n.each(function(n,a){a.setAttribute(e,t)})},C.prototype.removeAttr=function(e){return this.each(function(t,n){n.removeAttribute(e)})},C.prototype.html=function(e){return this.each(function(t,n){n.innerHTML=e})},C.prototype.val=function(e){return this.each(function(t,n){n.value=e})},C.prototype.append=function(e){return this.each(function(t,n){"object"==typeof e?n.appendChild(e):n.innerHTML=n.innerHTML+e})},C.prototype.remove=function(e){return this.each(function(t,n){e?n.removeChild(e):n.parentNode.removeChild(n)})},C.prototype.on=function(e,t){return this.each(function(n,a){a.attachEvent?a.attachEvent("on"+e,function(e){e.target=e.srcElement,t.call(a,e)}):a.addEventListener(e,t,!1)})},C.prototype.off=function(e,t){return this.each(function(n,a){a.detachEvent?a.detachEvent("on"+e,t):a.removeEventListener(e,t,!1)})},T.isLeapYear=function(e){return e%4===0&&e%100!==0||e%400===0},T.prototype.config={type:"date",range:!1,format:"yyyy-MM-dd",value:null,min:"1900-1-1",max:"2099-12-31",trigger:"focus",show:!1,showBottom:!0,btns:["clear","now","confirm"],lang:"cn",theme:"default",position:null,calendar:!1,mark:{},zIndex:null,done:null,change:null},T.prototype.lang=function(){var e=this,t=e.config,n={cn:{weeks:["日","一","二","三","四","五","六"],time:["时","分","秒"],timeTips:"选择时间",startTime:"开始时间",endTime:"结束时间",dateTips:"返回日期",month:["一","二","三","四","五","六","七","八","九","十","十一","十二"],tools:{confirm:"确定",clear:"清空",now:"现在"}},en:{weeks:["Su","Mo","Tu","We","Th","Fr","Sa"],time:["Hours","Minutes","Seconds"],timeTips:"Select Time",startTime:"Start Time",endTime:"End Time",dateTips:"Select Date",month:["Jan","Feb","Mar","Apr","May","Jun","Jul","Aug","Sep","Oct","Nov","Dec"],tools:{confirm:"Confirm",clear:"Clear",now:"Now"}}};return n[t.lang]||n.cn},T.prototype.init=function(){var e=this,t=e.config,n="yyyy|y|MM|M|dd|d|HH|H|mm|m|ss|s",a="static"===t.position,i={year:"yyyy",month:"yyyy-MM",date:"yyyy-MM-dd",time:"HH:mm:ss",datetime:"yyyy-MM-dd HH:mm:ss"};t.elem=w(t.elem),t.eventElem=w(t.eventElem),t.elem[0]&&(t.range===!0&&(t.range="-"),t.format===i.date&&(t.format=i[t.type]),e.format=t.format.match(new RegExp(n+"|.","g"))||[],e.EXP_IF="",e.EXP_SPLIT="",w.each(e.format,function(t,a){var i=new RegExp(n).test(a)?"\\d{"+function(){return new RegExp(n).test(e.format[0===t?t+1:t-1]||"")?/^yyyy|y$/.test(a)?4:a.length:/^yyyy$/.test(a)?"1,4":/^y$/.test(a)?"1,308":"1,2"}()+"}":"\\"+a;e.EXP_IF=e.EXP_IF+i,e.EXP_SPLIT=e.EXP_SPLIT+"("+i+")"}),e.EXP_IF=new RegExp("^"+(t.range?e.EXP_IF+"\\s\\"+t.range+"\\s"+e.EXP_IF:e.EXP_IF)+"$"),e.EXP_SPLIT=new RegExp("^"+e.EXP_SPLIT+"$",""),e.isInput(t.elem[0])||"focus"===t.trigger&&(t.trigger="click"),t.elem.attr("lay-key")||(t.elem.attr("lay-key",e.index),t.eventElem.attr("lay-key",e.index)),t.mark=w.extend({},t.calendar&&"cn"===t.lang?{"0-1-1":"元旦","0-2-14":"情人","0-3-8":"妇女","0-3-12":"植树","0-4-1":"愚人","0-5-1":"劳动","0-5-4":"青年","0-6-1":"儿童","0-9-10":"教师","0-9-18":"国耻","0-10-1":"国庆","0-12-25":"圣诞"}:{},t.mark),w.each(["min","max"],function(e,n){var a=[],i=[];if("number"==typeof t[n]){var r=t[n],o=(new Date).getTime(),s=864e5,l=new Date(r?r0)return!0;var a=w.elem("div",{"class":"layui-laydate-header"}),i=[function(){var e=w.elem("i",{"class":"layui-icon laydate-icon laydate-prev-y"});return e.innerHTML="",e}(),function(){var e=w.elem("i",{"class":"layui-icon laydate-icon laydate-prev-m"});return e.innerHTML="",e}(),function(){var e=w.elem("div",{"class":"laydate-set-ym"}),t=w.elem("span"),n=w.elem("span");return e.appendChild(t),e.appendChild(n),e}(),function(){var e=w.elem("i",{"class":"layui-icon laydate-icon laydate-next-m"});return e.innerHTML="",e}(),function(){var e=w.elem("i",{"class":"layui-icon laydate-icon laydate-next-y"});return e.innerHTML="",e}()],d=w.elem("div",{"class":"layui-laydate-content"}),c=w.elem("table"),m=w.elem("thead"),u=w.elem("tr");w.each(i,function(e,t){a.appendChild(t)}),m.appendChild(u),w.each(new Array(6),function(e){var t=c.insertRow(0);w.each(new Array(7),function(a){if(0===e){var i=w.elem("th");i.innerHTML=n.weeks[a],u.appendChild(i)}t.insertCell(a)})}),c.insertBefore(m,c.children[0]),d.appendChild(c),r[e]=w.elem("div",{"class":"layui-laydate-main laydate-main-list-"+e}),r[e].appendChild(a),r[e].appendChild(d),o.push(i),s.push(d),l.push(c)}),w(d).html(function(){var e=[],i=[];return"datetime"===t.type&&e.push(''+n.timeTips+""),w.each(t.btns,function(e,r){var o=n.tools[r]||"btn";t.range&&"now"===r||(a&&"clear"===r&&(o="cn"===t.lang?"重置":"Reset"),i.push(''+o+""))}),e.push('"),e.join("")}()),w.each(r,function(e,t){i.appendChild(t)}),t.showBottom&&i.appendChild(d),/^#/.test(t.theme)){var m=w.elem("style"),u=["#{{id}} .layui-laydate-header{background-color:{{theme}};}","#{{id}} .layui-this{background-color:{{theme}} !important;}"].join("").replace(/{{id}}/g,e.elemID).replace(/{{theme}}/g,t.theme);"styleSheet"in m?(m.setAttribute("type","text/css"),m.styleSheet.cssText=u):m.innerHTML=u,w(i).addClass("laydate-theme-molv"),i.appendChild(m)}e.remove(T.thisElemDate),a?t.elem.append(i):(document.body.appendChild(i),e.position()),e.checkDate().calendar(),e.changeEvent(),T.thisElemDate=e.elemID,"function"==typeof t.ready&&t.ready(w.extend({},t.dateTime,{month:t.dateTime.month+1}))},T.prototype.remove=function(e){var t=this,n=(t.config,w("#"+(e||t.elemID)));return n.hasClass(c)||t.checkDate(function(){n.remove()}),t},T.prototype.position=function(){var e=this,t=e.config,n=e.bindElem||t.elem[0],a=n.getBoundingClientRect(),i=e.elem.offsetWidth,r=e.elem.offsetHeight,o=function(e){return e=e?"scrollLeft":"scrollTop",document.body[e]|document.documentElement[e]},s=function(e){return document.documentElement[e?"clientWidth":"clientHeight"]},l=5,d=a.left,c=a.bottom;d+i+l>s("width")&&(d=s("width")-i-l),c+r+l>s()&&(c=a.top>r?a.top-r:s()-r,c-=2*l),t.position&&(e.elem.style.position=t.position),e.elem.style.left=d+("fixed"===t.position?0:o(1))+"px",e.elem.style.top=c+("fixed"===t.position?0:o())+"px"},T.prototype.hint=function(e){var t=this,n=(t.config,w.elem("div",{"class":h}));n.innerHTML=e||"",w(t.elem).find("."+h).remove(),t.elem.appendChild(n),clearTimeout(t.hinTimer),t.hinTimer=setTimeout(function(){w(t.elem).find("."+h).remove()},3e3)},T.prototype.getAsYM=function(e,t,n){return n?t--:t++,t<0&&(t=11,e--),t>11&&(t=0,e++),[e,t]},T.prototype.systemDate=function(e){var t=e||new Date;return{year:t.getFullYear(),month:t.getMonth(),date:t.getDate(),hours:e?e.getHours():0,minutes:e?e.getMinutes():0,seconds:e?e.getSeconds():0}},T.prototype.checkDate=function(e){var t,a,i=this,r=(new Date,i.config),o=r.dateTime=r.dateTime||i.systemDate(),s=i.bindElem||r.elem[0],l=(i.isInput(s)?"val":"html",i.isInput(s)?s.value:"static"===r.position?"":s.innerHTML),c=function(e){e.year>d[1]&&(e.year=d[1],a=!0),e.month>11&&(e.month=11,a=!0),e.hours>23&&(e.hours=0,a=!0),e.minutes>59&&(e.minutes=0,e.hours++,a=!0),e.seconds>59&&(e.seconds=0,e.minutes++,a=!0),t=n.getEndDate(e.month+1,e.year),e.date>t&&(e.date=t,a=!0)},m=function(e,t,n){var o=["startTime","endTime"];t=(t.match(i.EXP_SPLIT)||[]).slice(1),n=n||0,r.range&&(i[o[n]]=i[o[n]]||{}),w.each(i.format,function(s,l){var c=parseFloat(t[s]);t[s].length必须遵循下述格式:
"+(r.range?r.format+" "+r.range+" "+r.format:r.format)+"
已为你重置"),a=!0):l&&l.constructor===Date?r.dateTime=i.systemDate(l):(r.dateTime=i.systemDate(),delete i.startState,delete i.endState,delete i.startDate,delete i.endDate,delete i.startTime,delete i.endTime),c(o),a&&l&&i.setValue(r.range?i.endDate?i.parse():"":i.parse()),e&&e(),i)},T.prototype.mark=function(e,t){var n,a=this,i=a.config;return w.each(i.mark,function(e,a){var i=e.split("-");i[0]!=t[0]&&0!=i[0]||i[1]!=t[1]&&0!=i[1]||i[2]!=t[2]||(n=a||t[2])}),n&&e.html(''+n+""),a},T.prototype.limit=function(e,t,n,a){var i,r=this,o=r.config,l={},d=o[n>41?"endDate":"dateTime"],c=w.extend({},d,t||{});return w.each({now:c,min:o.min,max:o.max},function(e,t){l[e]=r.newDate(w.extend({year:t.year,month:t.month,date:t.date},function(){var e={};return w.each(a,function(n,a){e[a]=t[a]}),e}())).getTime()}),i=l.nowl.max,e&&e[i?"addClass":"removeClass"](s),i},T.prototype.calendar=function(e){var t,a,i,r=this,s=r.config,l=e||s.dateTime,c=new Date,m=r.lang(),u="date"!==s.type&&"datetime"!==s.type,h=e?1:0,y=w(r.table[h]).find("td"),f=w(r.elemHeader[h][2]).find("span");if(l.yeard[1]&&(l.year=d[1],r.hint("最高只能支持到公元"+d[1]+"年")),r.firstDate||(r.firstDate=w.extend({},l)),c.setFullYear(l.year,l.month,1),t=c.getDay(),a=n.getEndDate(l.month||12,l.year),i=n.getEndDate(l.month+1,l.year),w.each(y,function(e,n){var d=[l.year,l.month],c=0;n=w(n),n.removeAttr("class"),e=t&&e=n.firstDate.year&&(r.month=a.max.month,r.date=a.max.date),n.limit(w(i),r,t),M++}),w(u[f?0:1]).attr("lay-ym",M-8+"-"+T[1]).html(b+p+" - "+(M-1+p))}else if("month"===e)w.each(new Array(12),function(e){var i=w.elem("li",{"lay-ym":e}),s={year:T[0],month:e};e+1==T[1]&&w(i).addClass(o),i.innerHTML=r.month[e]+(f?"月":""),d.appendChild(i),T[0]=n.firstDate.year&&(s.date=a.max.date),n.limit(w(i),s,t)}),w(u[f?0:1]).attr("lay-ym",T[0]+"-"+T[1]).html(T[0]+p);else if("time"===e){var E=function(){w(d).find("ol").each(function(e,a){w(a).find("li").each(function(a,i){n.limit(w(i),[{hours:a},{hours:n[x].hours,minutes:a},{hours:n[x].hours,minutes:n[x].minutes,seconds:a}][e],t,[["hours"],["hours","minutes"],["hours","minutes","seconds"]][e])})}),a.range||n.limit(w(n.footer).find(g),n[x],0,["hours","minutes","seconds"])};a.range?n[x]||(n[x]={hours:0,minutes:0,seconds:0}):n[x]=i,w.each([24,60,60],function(e,t){var a=w.elem("li"),i=["

"+r.time[e]+"

    "];w.each(new Array(t),function(t){i.push(""+w.digit(t,2)+"")}),a.innerHTML=i.join("")+"
",d.appendChild(a)}),E()}if(y&&h.removeChild(y),h.appendChild(d),"year"===e||"month"===e)w(n.elemMain[t]).addClass("laydate-ym-show"),w(d).find("li").on("click",function(){var r=0|w(this).attr("lay-ym");if(!w(this).hasClass(s)){if(0===t)i[e]=r,l&&(n.startDate[e]=r),n.limit(w(n.footer).find(g),null,0);else if(l)n.endDate[e]=r;else{var c="year"===e?n.getAsYM(r,T[1]-1,"sub"):n.getAsYM(T[0],r,"sub");w.extend(i,{year:c[0],month:c[1]})}"year"===a.type||"month"===a.type?(w(d).find("."+o).removeClass(o),w(this).addClass(o),"month"===a.type&&"year"===e&&(n.listYM[t][0]=r,l&&(n[["startDate","endDate"][t]].year=r),n.list("month",t))):(n.checkDate("limit").calendar(),n.closeList()),n.setBtnStatus(),a.range||n.done(null,"change"),w(n.footer).find(D).removeClass(s)}});else{var S=w.elem("span",{"class":v}),k=function(){w(d).find("ol").each(function(e){var t=this,a=w(t).find("li");t.scrollTop=30*(n[x][C[e]]-2),t.scrollTop<=0&&a.each(function(e,n){if(!w(this).hasClass(s))return t.scrollTop=30*(e-2),!0})})},H=w(c[2]).find("."+v);k(),S.innerHTML=a.range?[r.startTime,r.endTime][t]:r.timeTips,w(n.elemMain[t]).addClass("laydate-time-show"),H[0]&&H.remove(),c[2].appendChild(S),w(d).find("ol").each(function(e){var t=this;w(t).find("li").on("click",function(){var r=0|this.innerHTML;w(this).hasClass(s)||(a.range?n[x][C[e]]=r:i[C[e]]=r,w(t).find("."+o).removeClass(o),w(this).addClass(o),E(),k(),(n.endDate||"time"===a.type)&&n.done(null,"change"),n.setBtnStatus())})})}return n},T.prototype.listYM=[],T.prototype.closeList=function(){var e=this;e.config;w.each(e.elemCont,function(t,n){w(this).find("."+m).remove(),w(e.elemMain[t]).removeClass("laydate-ym-show laydate-time-show")}),w(e.elem).find("."+v).remove()},T.prototype.setBtnStatus=function(e,t,n){var a,i=this,r=i.config,o=w(i.footer).find(g),d=r.range&&"date"!==r.type&&"time"!==r.type;d&&(t=t||i.startDate,n=n||i.endDate,a=i.newDate(t).getTime()>i.newDate(n).getTime(),i.limit(null,t)||i.limit(null,n)?o.addClass(s):o[a?"addClass":"removeClass"](s),e&&a&&i.hint("string"==typeof e?l.replace(/日期/g,e):l))},T.prototype.parse=function(e,t){var n=this,a=n.config,i=t||(e?w.extend({},n.endDate,n.endTime):a.range?w.extend({},n.startDate,n.startTime):a.dateTime),r=n.format.concat();return w.each(r,function(e,t){/yyyy|y/.test(t)?r[e]=w.digit(i.year,t.length):/MM|M/.test(t)?r[e]=w.digit(i.month+1,t.length):/dd|d/.test(t)?r[e]=w.digit(i.date,t.length):/HH|H/.test(t)?r[e]=w.digit(i.hours,t.length):/mm|m/.test(t)?r[e]=w.digit(i.minutes,t.length):/ss|s/.test(t)&&(r[e]=w.digit(i.seconds,t.length))}),a.range&&!e?r.join("")+" "+a.range+" "+n.parse(1):r.join("")},T.prototype.newDate=function(e){return e=e||{},new Date(e.year||1,e.month||0,e.date||1,e.hours||0,e.minutes||0,e.seconds||0)},T.prototype.setValue=function(e){var t=this,n=t.config,a=t.bindElem||n.elem[0],i=t.isInput(a)?"val":"html";return"static"===n.position||w(a)[i](e||""),this},T.prototype.stampRange=function(){var e,t,n=this,a=n.config,i=w(n.elem).find("td");if(a.range&&!n.endDate&&w(n.footer).find(g).addClass(s),n.endDate)return e=n.newDate({year:n.startDate.year,month:n.startDate.month,date:n.startDate.date}).getTime(),t=n.newDate({year:n.endDate.year,month:n.endDate.month,date:n.endDate.date}).getTime(),e>t?n.hint(l):void w.each(i,function(a,i){var r=w(i).attr("lay-ymd").split("-"),s=n.newDate({year:r[0],month:r[1]-1,date:r[2]}).getTime();w(i).removeClass(u+" "+o),s!==e&&s!==t||w(i).addClass(w(i).hasClass(y)||w(i).hasClass(f)?u:o),s>e&&s + + + + +Created by iconfont + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/groups/static/groups/time/laydate/theme/default/font/iconfont.ttf b/groups/static/groups/time/laydate/theme/default/font/iconfont.ttf new file mode 100644 index 00000000..0bd6c4a8 Binary files /dev/null and b/groups/static/groups/time/laydate/theme/default/font/iconfont.ttf differ diff --git a/groups/static/groups/time/laydate/theme/default/font/iconfont.woff b/groups/static/groups/time/laydate/theme/default/font/iconfont.woff new file mode 100644 index 00000000..bfe55996 Binary files /dev/null and b/groups/static/groups/time/laydate/theme/default/font/iconfont.woff differ diff --git a/groups/static/groups/time/laydate/theme/default/laydate.css b/groups/static/groups/time/laydate/theme/default/laydate.css new file mode 100644 index 00000000..c7e15086 --- /dev/null +++ b/groups/static/groups/time/laydate/theme/default/laydate.css @@ -0,0 +1,2 @@ +/*! laydate-v5.0.9 日期与时间组件 MIT License http://www.layui.com/laydate/ By 贤心 */ +.laydate-set-ym,.layui-laydate,.layui-laydate *,.layui-laydate-list{box-sizing:border-box}html #layuicss-laydate{display:none;position:absolute;width:1989px}.layui-laydate *{margin:0;padding:0}.layui-laydate{position:absolute;z-index:66666666;margin:5px 0;border-radius:2px;font-size:14px;-webkit-animation-duration:.3s;animation-duration:.3s;-webkit-animation-fill-mode:both;animation-fill-mode:both;-webkit-animation-name:laydate-upbit;animation-name:laydate-upbit}.layui-laydate-main{width:272px}.layui-laydate-content td,.layui-laydate-header *,.layui-laydate-list li{transition-duration:.3s;-webkit-transition-duration:.3s}@-webkit-keyframes laydate-upbit{from{-webkit-transform:translate3d(0,20px,0);opacity:.3}to{-webkit-transform:translate3d(0,0,0);opacity:1}}@keyframes laydate-upbit{from{transform:translate3d(0,20px,0);opacity:.3}to{transform:translate3d(0,0,0);opacity:1}}.layui-laydate-static{position:relative;z-index:0;display:inline-block;margin:0;-webkit-animation:none;animation:none}.laydate-ym-show .laydate-next-m,.laydate-ym-show .laydate-prev-m{display:none!important}.laydate-ym-show .laydate-next-y,.laydate-ym-show .laydate-prev-y{display:inline-block!important}.laydate-time-show .laydate-set-ym span[lay-type=month],.laydate-time-show .laydate-set-ym span[lay-type=year],.laydate-time-show .layui-laydate-header .layui-icon,.laydate-ym-show .laydate-set-ym span[lay-type=month]{display:none!important}.layui-laydate-header{position:relative;line-height:30px;padding:10px 70px 5px}.laydate-set-ym span,.layui-laydate-header i{padding:0 5px;cursor:pointer}.layui-laydate-header *{display:inline-block;vertical-align:bottom}.layui-laydate-header i{position:absolute;top:10px;color:#999;font-size:18px}.layui-laydate-header i.laydate-prev-y{left:15px}.layui-laydate-header i.laydate-prev-m{left:45px}.layui-laydate-header i.laydate-next-y{right:15px}.layui-laydate-header i.laydate-next-m{right:45px}.laydate-set-ym{width:100%;text-align:center;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.laydate-time-text{cursor:default!important}.layui-laydate-content{position:relative;padding:10px;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none}.layui-laydate-content table{border-collapse:collapse;border-spacing:0}.layui-laydate-content td,.layui-laydate-content th{width:36px;height:30px;padding:5px;text-align:center}.layui-laydate-content td{position:relative;cursor:pointer}.laydate-day-mark{position:absolute;left:0;top:0;width:100%;height:100%;line-height:30px;font-size:12px;overflow:hidden}.laydate-day-mark::after{position:absolute;content:'';right:2px;top:2px;width:5px;height:5px;border-radius:50%}.layui-laydate-footer{position:relative;height:46px;line-height:26px;padding:10px 20px}.layui-laydate-footer span{margin-right:15px;display:inline-block;cursor:pointer;font-size:12px}.layui-laydate-footer span:hover{color:#5FB878}.laydate-footer-btns{position:absolute;right:10px;top:10px}.laydate-footer-btns span{height:26px;line-height:26px;margin:0 0 0 -1px;padding:0 10px;border:1px solid #C9C9C9;background-color:#fff;white-space:nowrap;vertical-align:top;border-radius:2px}.layui-laydate-list>li,.layui-laydate-range .layui-laydate-main{display:inline-block;vertical-align:middle}.layui-laydate-list{position:absolute;left:0;top:0;width:100%;height:100%;padding:10px;background-color:#fff}.layui-laydate-list>li{position:relative;width:33.3%;height:36px;line-height:36px;margin:3px 0;text-align:center;cursor:pointer}.laydate-month-list>li{width:25%;margin:17px 0}.laydate-time-list>li{height:100%;margin:0;line-height:normal;cursor:default}.laydate-time-list p{position:relative;top:-4px;line-height:29px}.laydate-time-list ol{height:181px;overflow:hidden}.laydate-time-list>li:hover ol{overflow-y:auto}.laydate-time-list ol li{width:130%;padding-left:33px;line-height:30px;text-align:left;cursor:pointer}.layui-laydate-hint{position:absolute;top:115px;left:50%;width:250px;margin-left:-125px;line-height:20px;padding:15px;text-align:center;font-size:12px}.layui-laydate-range{width:546px}.layui-laydate-range .laydate-main-list-0 .laydate-next-m,.layui-laydate-range .laydate-main-list-0 .laydate-next-y,.layui-laydate-range .laydate-main-list-1 .laydate-prev-m,.layui-laydate-range .laydate-main-list-1 .laydate-prev-y{display:none}.layui-laydate-range .laydate-main-list-1 .layui-laydate-content{border-left:1px solid #e2e2e2}.layui-laydate,.layui-laydate-hint{border:1px solid #d2d2d2;box-shadow:0 2px 4px rgba(0,0,0,.12);background-color:#fff;color:#666}.layui-laydate-header{border-bottom:1px solid #e2e2e2}.layui-laydate-header i:hover,.layui-laydate-header span:hover{color:#5FB878}.layui-laydate-content{border-top:none 0;border-bottom:none 0}.layui-laydate-content th{font-weight:400;color:#333}.layui-laydate-content td{color:#666}.layui-laydate-content td.laydate-selected{background-color:#00F7DE}.laydate-selected:hover{background-color:#00F7DE!important}.layui-laydate-content td:hover,.layui-laydate-list li:hover{background-color:#eaeaea;color:#333}.laydate-time-list li ol{margin:0;padding:0;border:1px solid #e2e2e2;border-left-width:0}.laydate-time-list li:first-child ol{border-left-width:1px}.laydate-time-list>li:hover{background:0 0}.layui-laydate-content .laydate-day-next,.layui-laydate-content .laydate-day-prev{color:#d2d2d2}.laydate-selected.laydate-day-next,.laydate-selected.laydate-day-prev{background-color:#f8f8f8!important}.layui-laydate-footer{border-top:1px solid #e2e2e2}.layui-laydate-hint{color:#FF5722}.laydate-day-mark::after{background-color:#5FB878}.layui-laydate-content td.layui-this .laydate-day-mark::after{display:none}.layui-laydate-footer span[lay-type=date]{color:#5FB878}.layui-laydate .layui-this{background-color:#009688!important;color:#fff!important}.layui-laydate .laydate-disabled,.layui-laydate .laydate-disabled:hover{background:0 0!important;color:#d2d2d2!important;cursor:not-allowed!important;-moz-user-select:none;-webkit-user-select:none;-ms-user-select:none}.laydate-theme-molv{border:none}.laydate-theme-molv.layui-laydate-range{width:548px}.laydate-theme-molv .layui-laydate-main{width:274px}.laydate-theme-molv .layui-laydate-header{border:none;background-color:#009688}.laydate-theme-molv .layui-laydate-header i,.laydate-theme-molv .layui-laydate-header span{color:#f6f6f6}.laydate-theme-molv .layui-laydate-header i:hover,.laydate-theme-molv .layui-laydate-header span:hover{color:#fff}.laydate-theme-molv .layui-laydate-content{border:1px solid #e2e2e2;border-top:none;border-bottom:none}.laydate-theme-molv .laydate-main-list-1 .layui-laydate-content{border-left:none}.laydate-theme-grid .laydate-month-list>li,.laydate-theme-grid .laydate-year-list>li,.laydate-theme-grid .layui-laydate-content td,.laydate-theme-grid .layui-laydate-content thead,.laydate-theme-molv .layui-laydate-footer{border:1px solid #e2e2e2}.laydate-theme-grid .laydate-selected,.laydate-theme-grid .laydate-selected:hover{background-color:#f2f2f2!important;color:#009688!important}.laydate-theme-grid .laydate-selected.laydate-day-next,.laydate-theme-grid .laydate-selected.laydate-day-prev{color:#d2d2d2!important}.laydate-theme-grid .laydate-month-list,.laydate-theme-grid .laydate-year-list{margin:1px 0 0 1px}.laydate-theme-grid .laydate-month-list>li,.laydate-theme-grid .laydate-year-list>li{margin:0 -1px -1px 0}.laydate-theme-grid .laydate-year-list>li{height:43px;line-height:43px}.laydate-theme-grid .laydate-month-list>li{height:71px;line-height:71px}@font-face{font-family:laydate-icon;src:url(font/iconfont.eot);src:url(font/iconfont.eot#iefix) format('embedded-opentype'),url(font/iconfont.svg#iconfont) format('svg'),url(font/iconfont.woff) format('woff'),url(font/iconfont.ttf) format('truetype')}.laydate-icon{font-family:laydate-icon!important;font-size:16px;font-style:normal;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale} \ No newline at end of file diff --git a/groups/templates/groups/exam.html b/groups/templates/groups/exam.html new file mode 100644 index 00000000..d6bba27c --- /dev/null +++ b/groups/templates/groups/exam.html @@ -0,0 +1,134 @@ +{% extends "./base.html" %} + +{% block title %}隐患统计{% endblock %} + +{% block content %} +{% load static %} +
+

未遂事件统计

+
+
+
+ 开始日期: + 结束日期: + + +
+ +
+
+ + + + + + + + + + + + {% endblock %} diff --git a/groups/templates/groups/miss.html b/groups/templates/groups/miss.html new file mode 100644 index 00000000..0c07cdd5 --- /dev/null +++ b/groups/templates/groups/miss.html @@ -0,0 +1,135 @@ +{% extends "./base.html" %} + +{% block title %}隐患统计{% endblock %} + +{% block content %} +{% load static %} +
+

未遂事件统计

+
+
+
+ 开始日期: + 结束日期: + + +
+ +
+
+ + + + + + + + + + + + + {% endblock %} diff --git a/groups/templates/groups/observe.html b/groups/templates/groups/observe.html index ece943a7..1660bb1e 100644 --- a/groups/templates/groups/observe.html +++ b/groups/templates/groups/observe.html @@ -9,33 +9,21 @@
- - - - + 开始日期: + 结束日期:
-
+
+ + + @@ -45,131 +33,100 @@ $(function () { - var currentYear = new Date().getFullYear(); - var select = document.getElementById("YearNum"); - for (var i = 0; i <= 3; i++) { - var theOption = document.createElement("option"); - theOption.innerHTML = currentYear - i; - theOption.value = currentYear - i; - select.appendChild(theOption); - } - var date = new Date(); - var year = date.getFullYear(); - var month = date.getMonth() + 1; - $("#YearNum").val(year); - $("#banqType").val(month); - gczxt() + laydate.render({ + elem: '#test' + , format: 'yyyy-MM-dd' //可任意组合 + }); + laydate.render({ + elem: '#test2' + , format: 'yyyy-MM-dd' //可任意组合 + }); + observe(); }); function funTypeChange() { - gczxt() + observe(); } - function gczxt() {//行为观察折线图 - var y = $("#YearNum").val(); - var m = $("#banqType").val(); - //行为观察折线图 + + + function observe() { + + var start = $("#test").val(); + var end = $("#test2").val(); + $.ajax({ type: "get", async: true, //异步请求(同步请求将会锁住浏览器,用户其他操作必须等待请求完成才可以执行) - url: "/groups/api/observeChart?code=tbpic&year=" + y + "&month=" + m, //请求发送 + url: "/groups/api/observeChart?code=obv&start=" + start + "&end=" + end, //请求发送 dataType: "json", //返回数据形式为json success: function (data) { - //请求成功时执行该函数内容,data即为服务器返回的json对象 console.log(data); - var gcChart2 = echarts.init(document.getElementById("troubchart")); + //请求成功时执行该函数内容,data即为服务器返回的json对象 + var obvChart = echarts.init(document.getElementById("obvchart")); + var obvnum = []; var companyName = []; - if (data.list != null) { - $.each(data.list, function (i, item) { + if (data.data.observelist != null) { + $.each(data.data.observelist, function (i, item) { + + + obvnum.push(item.number); companyName.push(item.usecomp__partname); }) - gcChart2.setOption(option = { - title: { - text: '行为观察折线图' - }, - tooltip: { - trigger: 'axis' - }, - legend: { - data: ['人员的反映', '员工的位置', '个人防护装备', '工具和设备', '程序和标准', '人体工程学', '环境整洁'] - }, - grid: { - left: '3%', - right: '4%', - bottom: '3%', - containLabel: true - }, - toolbox: { - feature: { - saveAsImage: {} - } - }, - xAxis: { - type: 'category', - boundaryGap: false, - data: companyName - }, - yAxis: { - type: 'value' - }, - series: [ - { - name: '人员的反映', - type: 'line', - stack: '总量', - data: data.userfy + + obvChart.setOption( + + option = { + color: ['#00a65a'], + tooltip: { + trigger: 'axis', + axisPointer: { // 坐标轴指示器,坐标轴触发有效 + type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' + } }, - { - name: '员工的位置', - type: 'line', - stack: '总量', - data: data.userwz + + title: { + text: '本集团各公司行为观察统计图' }, - { - name: '个人防护装备', - type: 'line', - stack: '总量', - data: data.grfh + tooltip: {}, + legend: { + data: ['公司行为观察总数'] }, - { - name: '工具和设备', - type: 'line', - stack: '总量', - data: data.gjhsb + xAxis: { + type: 'category', + data: companyName, + boundaryGap: [0, 0.01], + axisLabel: { + interval: 0,//横轴信息全部显示 + rotate: -30,//-30度角倾斜显示 + } }, - { - name: '程序和标准', - type: 'line', - stack: '总量', - data: data.cxhbz - } - , - { - name: '人体工程学', - type: 'line', - stack: '总量', - data: data.rtgcx + grid: { + y2: 140 }, - { - name: '环境整洁', - type: 'line', - stack: '总量', - data: data.hjzj - } - ] - }); - }}, + yAxis: {}, + series: [{ + name: '公司行为观察总数', + data: obvnum, + type: 'bar' + }] + + } + + ); + + } + }, error: function (errorMsg) { - gcChart2.hideLoading(); + obvChart.hideLoading(); } }); + } - - {% endblock %} diff --git a/groups/templates/groups/risk.html b/groups/templates/groups/risk.html new file mode 100644 index 00000000..c5e442d6 --- /dev/null +++ b/groups/templates/groups/risk.html @@ -0,0 +1,134 @@ +{% extends "./base.html" %} + +{% block title %}风险管控{% endblock %} + +{% block content %} +{% load static %} +
+

风险管控统计

+
+
+
+ 开始日期: + 结束日期: + + +
+ +
+
+ + + + + + + + + + + + {% endblock %} diff --git a/groups/templates/groups/train.html b/groups/templates/groups/train.html new file mode 100644 index 00000000..b0a18930 --- /dev/null +++ b/groups/templates/groups/train.html @@ -0,0 +1,136 @@ +{% extends "./base.html" %} + +{% block title %}教育培训统计{% endblock %} + +{% block content %} +{% load static %} +
+

教育培训统计

+
+
+
+ 开始日期: + 结束日期: + + + + + +
+
+
+ + + + + + + + + + + {% endblock %} diff --git a/groups/templates/groups/troublepic.html b/groups/templates/groups/troublepic.html index 3fa06d89..e79004bd 100644 --- a/groups/templates/groups/troublepic.html +++ b/groups/templates/groups/troublepic.html @@ -7,15 +7,13 @@

隐患统计

-
-
- -
- -
-
- +
+
+ 开始日期: + 结束日期: + +
@@ -24,9 +22,8 @@ - - - + + @@ -35,37 +32,30 @@ $(function () { - - $('.datepicker').datepicker({ - language: 'zh-CN', - format: 'yyyy-mm-dd hh:00:00',//日期格式。可以将日期格式,定成年月日时,分秒为0。 - weekStart: 1, - todayBtn: 1, - autoclose: 1, - todayHighlight: 1, - startView: 2, - forceParse: 0, - showMeridian: 1 - }); - var times = $('#time').value; - alert(times) + + laydate.render({ + elem: '#test' + , format: 'yyyy-MM-dd' //可任意组合 + }); + laydate.render({ + elem: '#test2' + , format: 'yyyy-MM-dd' //可任意组合 + }); troub(); }); - - function funTypeChange() { - var times = $('#time').value; - alert(times) troub(); } function troub() { + var start = $("#test").val(); + var end = $("#test2").val(); $.ajax({ type: "get", async: true, //异步请求(同步请求将会锁住浏览器,用户其他操作必须等待请求完成才可以执行) - url: "/groups/api/troubleChart?code=tbpic&starttime=" + starttime + "&endtime=" + endtime, //请求发送 + url: "/groups/api/troubleChart?code=tbpic&start=" + start + "&end=" + end, //请求发送 dataType: "json", //返回数据形式为json success: function (data) { console.log(data.data.troublelist); @@ -87,7 +77,7 @@ yhChart.setOption( option = { - color: ['#3398DB'], + color: ['#f39c12'], tooltip: { trigger: 'axis', axisPointer: { // 坐标轴指示器,坐标轴触发有效 @@ -96,15 +86,23 @@ }, title: { - text: '本集团' + y + '年' + m + '月各公司隐患统计图' + text: '本集团各公司隐患统计图' }, tooltip: {}, legend: { data: ['公司隐患总数'] }, + grid: { + y2: 140 + }, xAxis: { type: 'category', - data: companyName + data: companyName, + boundaryGap: [0, 0.01], + axisLabel: { + interval: 0,//横轴信息全部显示 + rotate: -30,//-30度角倾斜显示 + } }, yAxis: {}, series: [{ diff --git a/groups/urls.py b/groups/urls.py index 6361e26a..de3bfd0c 100644 --- a/groups/urls.py +++ b/groups/urls.py @@ -11,13 +11,18 @@ urlpatterns = [ path('company/', views.company, name='groups_company'), path('trouble/', views.trouble, name='groups_trouble'),#隐患排查统计图 path('observe/', views.observe, name='groups_observe'),#行为观察统计图 - path('miss/', views.job, name='groups_miss'),#未遂事件统计图 - path('risk/', views.job, name='groups_risk'),#风险管控统计图 - path('tain/', views.job, name='groups_train'),#教育培训统计图 - path('test/', views.job, name='groups_test'),#在线考试统计图 + path('miss/', views.miss, name='groups_miss'),#未遂事件统计图 + path('risk/', views.risk, name='groups_risk'),#风险管控统计图 + path('tain/', views.train, name='groups_train'),#教育培训统计图 + path('test/', views.exam, name='groups_test'),#在线考试统计图 path('refresh_captcha/', views.refresh_captcha), path('updateposition/',views.updateposition), path('api/positions',views.apipositions), path('api/troubleChart',views.troubleChart), - path('api/observeChart',views.observeChart) + path('api/observeChart',views.observeChart), + path('api/missChart',views.missChart), + path('api/riskChart',views.riskChart), + path('api/trainChart',views.trainChart), + path('api/examChart',views.examChart) + ] diff --git a/groups/views.py b/groups/views.py index 767ca28c..78a5b6fd 100644 --- a/groups/views.py +++ b/groups/views.py @@ -118,34 +118,93 @@ def trouble(request):#隐患排查 return render(request, 'groups/troublepic.html', locals()) def observe(request):#行为观察 return render(request, 'groups/observe.html', locals()) +def miss(request):#未遂事件 + return render(request, 'groups/miss.html', locals()) +def risk(request):#风险管控 + return render(request, 'groups/risk.html', locals()) +def train(request):#教育培训 + return render(request, 'groups/train.html', locals()) +def exam(request):#在线考试 + return render(request, 'groups/exam.html', locals()) def troubleChart(request):#隐患统计图 code = request.GET.get('code') - + start = request.GET.get('start') + end = request.GET.get('end') if code=='tbpic': - yhcompanys=[] - yhcompanyscount=[] - companys = GroupUser.objects.get(id = request.session['user_id']).group.members.all() troublelist = s_models.Trouble.objects.filter(deletemark=1,usecomp__in=companys).values('usecomp__partid','usecomp__partname').annotate(number = Count('troubleid')) - if request.GET.get('starttime'):#开始时间 - a = troublelist.filter(fxsj__gte=request.GET.get('qssj')) - if request.GET.get('endtime'):#结束时间 - a = troublelist.filter(fxsj__lte=request.GET.get('jssj')) - return HttpResponse(json.dumps({'code':1,'data':{'troublelist':list(a)}}), content_type='application/json') + if start: + troublelist = troublelist.filter(fxsj__gte=start) + if end: + troublelist = troublelist.filter(fxsj__lte=end) + return HttpResponse(json.dumps({'code':1,'data':{'troublelist':list(troublelist)}}), content_type='application/json') def observeChart(request):#行为观察 code = request.GET.get('code') - year = int(request.GET.get('year')) - month =int( request.GET.get('month')) - if code=='tbpic': - userfy=[]#人员反映 - userwz=[]#员工的位置 - grfh=[]#个人防护装备 - gjhsb=[]#工具和设备 - cxhbz=[]#程序和标准 - rtgcx=[]#人体工程学 - hjzj=[]#环境整洁 - first_day,first_day_of_next_month = gettime(datetime(year,month,1)) - companys = GroupUser.objects.get(id = request.session['user_id']).group.members.all().values('partname') - - return HttpResponse(json.dumps({'code':1,'data':{'list':list(Observe)},'userfy':userfy,'userwz':userwz,'grfh':grfh,'gjhsb':gjhsb,'cxhbz':cxhbz,'rtgcx':rtgcx,'hjzj':hjzj,}), content_type='application/json') - + start = request.GET.get('start') + end = request.GET.get('end') + if code=='obv': + companys = GroupUser.objects.get(id = request.session['user_id']).group.members.all() + observelist = s_models.Observe.objects.filter(deletemark=1,usecomp__in=companys).values('usecomp__partid','usecomp__partname').annotate(number = Count('lookid')) + if start: + observelist = observelist.filter(looktime__gte=start) + if end: + observelist = observelist.filter(looktime__lte=end) + return HttpResponse(json.dumps({'code':1,'data':{'observelist':list(observelist)}}), content_type='application/json') + +def missChart(request):#未遂事件 + code = request.GET.get('code') + start = request.GET.get('start') + end = request.GET.get('end') + if code=='miss': + + companys = GroupUser.objects.get(id = request.session['user_id']).group.members.all() + misslist = s_models.Miss.objects.filter(deletemark=1,usecomp__in=companys).values('usecomp__partid','usecomp__partname').annotate(number = Count('missid')) + if start: + misslist = misslist.filter(misstime__gte=start) + if end: + misslist = misslist.filter(misstime__lte=end) + return HttpResponse(json.dumps({'code':1,'data':{'misslist':list(misslist)}}), content_type='application/json') + +def riskChart(request):#风险管控 + code = request.GET.get('code') + start = request.GET.get('start') + end = request.GET.get('end') + if code=='risk': + + companys = GroupUser.objects.get(id = request.session['user_id']).group.members.all() + risklist = s_models.Risk.objects.filter(usecomp__in=companys).values('usecomp__partid','usecomp__partname').annotate(number = Count('id')) + if start: + risklist = risklist.filter(createtime__gte=start) + if end: + risklist = risklist.filter(createtime__lte=end) + return HttpResponse(json.dumps({'code':1,'data':{'risklist':list(risklist)}}), content_type='application/json') +def trainChart(request):#教育培训 + code = request.GET.get('code') + start = request.GET.get('start') + end = request.GET.get('end') + if code=='train': + companys = GroupUser.objects.get(id = request.session['user_id']).group.members.all() + trainlist = s_models.Train.objects.filter(usecomp__in=companys).values('usecomp__partid','usecomp__partname').annotate(number = Count('trainid')) + if start: + trainlist = trainlist.filter(starttime__gte=start) + if end: + trainlist = trainlist.filter(starttime__lte=end) + return HttpResponse(json.dumps({'code':1,'data':{'trainlist':list(trainlist)}}), content_type='application/json') + +def examChart(request):#在线考试 + code = request.GET.get('code') + start = request.GET.get('start') + end = request.GET.get('end') + examjson = [] + if code=='exam': + companys = GroupUser.objects.get(id = request.session['user_id']).group.members.all() + + for i in companys: + examlist = s_models.ExamTest.objects.filter(usecomps__contains=','+i+',').annotate(number = Count('id')) + if start: + examlist = examlist.filter(starttime__gte=start) + if end: + examlist = examlist.filter(starttime__lte=end) + examjson.append({'companyName':i,'number':examlist.number}) + return HttpResponse(json.dumps({'code':1,'data':examjson}), content_type='application/json') + diff --git a/safesite/migrations/0281_remove_companyinfo_liaison_fax.py b/safesite/migrations/0281_remove_companyinfo_liaison_fax.py new file mode 100644 index 00000000..a32fe6fe --- /dev/null +++ b/safesite/migrations/0281_remove_companyinfo_liaison_fax.py @@ -0,0 +1,17 @@ +# Generated by Django 2.1.5 on 2019-10-24 10:56 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('safesite', '0280_auto_20191023_1711'), + ] + + operations = [ + # migrations.RemoveField( + # model_name='companyinfo', + # name='liaison_fax', + # ), + ] diff --git a/safesite/migrations/0282_remove_companyinfo_liaison_fax.py b/safesite/migrations/0282_remove_companyinfo_liaison_fax.py new file mode 100644 index 00000000..8829e0ca --- /dev/null +++ b/safesite/migrations/0282_remove_companyinfo_liaison_fax.py @@ -0,0 +1,17 @@ +# Generated by Django 2.1.5 on 2019-10-24 11:09 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('safesite', '0281_remove_companyinfo_liaison_fax'), + ] + + operations = [ + # migrations.RemoveField( + # model_name='companyinfo', + # name='liaison_fax', + # ), + ] diff --git a/safesite/migrations/0283_remove_companyinfo_liaison_fax.py b/safesite/migrations/0283_remove_companyinfo_liaison_fax.py new file mode 100644 index 00000000..95023475 --- /dev/null +++ b/safesite/migrations/0283_remove_companyinfo_liaison_fax.py @@ -0,0 +1,17 @@ +# Generated by Django 2.1.5 on 2019-10-24 11:11 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('safesite', '0282_remove_companyinfo_liaison_fax'), + ] + + operations = [ + # migrations.RemoveField( + # model_name='companyinfo', + # name='liaison_fax', + # ), + ] diff --git a/safesite/migrations/0284_remove_companyinfo_liaison_fax.py b/safesite/migrations/0284_remove_companyinfo_liaison_fax.py new file mode 100644 index 00000000..317341e6 --- /dev/null +++ b/safesite/migrations/0284_remove_companyinfo_liaison_fax.py @@ -0,0 +1,17 @@ +# Generated by Django 2.1.5 on 2019-10-24 11:13 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('safesite', '0283_remove_companyinfo_liaison_fax'), + ] + + operations = [ + # migrations.RemoveField( + # model_name='companyinfo', + # name='liaison_fax', + # ), + ] diff --git a/safesite/migrations/0285_remove_companyinfo_liaison_fax.py b/safesite/migrations/0285_remove_companyinfo_liaison_fax.py new file mode 100644 index 00000000..9d7b4a7e --- /dev/null +++ b/safesite/migrations/0285_remove_companyinfo_liaison_fax.py @@ -0,0 +1,17 @@ +# Generated by Django 2.1.5 on 2019-10-24 11:20 + +from django.db import migrations + + +class Migration(migrations.Migration): + + dependencies = [ + ('safesite', '0284_remove_companyinfo_liaison_fax'), + ] + + operations = [ + # migrations.RemoveField( + # model_name='companyinfo', + # name='liaison_fax', + # ), + ]