var selfOrgId = localStorage.getItem('selfOrgId'); var intervalTime = 5 * 1000; $(function() { findXmgkEcharts(); findSgryEcharts(); //人员管理-施工人员 findRiskEcharts(); //风险管控 proMoneyEcharts(); //工程造价 aqjcPhoto(); //安全检查 findZypEcharts(); //作业票 loading(); projectProgress(); //工程进度 var myVid = document.getElementById("xcpVideo"); myVid.muted = true; }); var progressIndex = 0; function projectProgress() { $.ajax({ type: 'POST', beforeSend: function(request) { request.setRequestHeader("token", token); }, url: smz_web_url + 'progressOverHaul/getProProgress', data: { selfOrgId: selfOrgId }, dataType: "json", success: function(data) { console.log("data", data); showProgressProName = ""; if (data.length > 0) { initProgress(data); if (data != null && data.length > 0) { window.setInterval(function() { initProgress(data); }, intervalTime); } } }, error: function(err) { progressIndex = 0; } }); } var showProgressProName = ""; function initProgress(data) { var orgName = data[progressIndex].orgName; var proName = data[progressIndex].proName; showProgressProName = proName; if (proName.length > 50) { proName = proName.substring(0, 20) + "..." + proName.substring(proName.length - 20, proName.length); } var plan = data[progressIndex].planProgress; var actual = data[progressIndex].actualProgressRatio; var planStartTime = data[progressIndex].planStartTime; var planEndTime = data[progressIndex].planEndTime; var statu = data[progressIndex].statu; var isNormal = "正常"; if (statu == "1" || (statu == "0" && parseFloat(plan) <= parseFloat(actual))) { isNormal = "正常"; $(".isNormal").css("color", "rgb(64,221,154)"); } else { isNormal = "延期"; $(".isNormal").css("color", "rgb(245,128,155)"); } $("#orgName").text(orgName); $("#proName").text(proName); $(".isNormal").text(isNormal); $("#planStartTime").text(planStartTime); $("#planEndTime").text(planEndTime); var plan_span = plan; var actual_span = actual; $("#fristDiv").html(""); $("#secondDiv").html(""); $("#actual_span").remove(); $("#plan_span").remove(); if (parseFloat(plan) > parseFloat(actual)) { plan = parseFloat(plan) - parseFloat(actual); $("#fristDiv").css("width", actual + "%"); $("#secondDiv").css("width", plan + "%"); var html1 = ""; if (plan < 13) { html1 = '计划进度'; } else { html1 = '计划进度'; } $("#secondDiv").append(html1); var html2 = ""; if (actual >= 13 && actual < 87) { html2 = '实际进度'; } else if (actual >= 87) { var html = '实际进度'; $("#contentDiv").append(html); } else if (actual < 13) { var html = '实际进度'; $("#contentDiv").append(html); } $("#fristDiv").append(html2); } else { actual = parseFloat(actual); plan = 0; $("#fristDiv").css("width", actual + "%"); $("#secondDiv").css("width", plan + "%"); var html3 = '计划进度'; $("#contentDiv").append(html3); var html2 = ""; if (actual >= 13 && actual < 87) { html2 = '实际进度'; } else if (actual >= 87) { var html = '实际进度'; $("#contentDiv").append(html); } else if (actual < 13) { var html = '实际进度'; $("#contentDiv").append(html); } $("#fristDiv").append(html2); } progressIndex++; if (progressIndex == data.length) { progressIndex = 0; } } function showProgress() { localStorage.setItem("orgName", ""); localStorage.setItem("proName", showProgressProName); var index = top.layer.open({ title: false, type: 2, content: '../../page/statistics/projectProgess.html', area: ['90%', '90%'], maxmin: false }); } /** * 项目概况数据获取 */ function findXmgkEcharts() { $.ajax({ type: 'POST', beforeSend: function(request) { request.setRequestHeader("token", token); }, url: smz_web_url + 'pro/getProNum', data: { selfOrgId: selfOrgId }, dataType: "json", success: function(data) { var vol = data.obj.vol; var bd = data.obj.bd; var xl = data.obj.xl; console.log("data",data); xmgkEcharts(vol, bd, xl); }, error:function(xhr, textStatus, errorThrown){ console.log("xhr",xhr); console.log("textStatus",textStatus); console.log("errorThrown",errorThrown); } }); } /** * 施工人员数据获取 */ function findSgryEcharts() { $("#onlineNums").html("0"); $("#attendanceNums").html("0"); $.ajax({ type: 'POST', beforeSend: function(request) { request.setRequestHeader("token", token); }, url: smz_web_url + 'person/getWorkerNum', data: { selfOrgId: selfOrgId }, dataType: "json", success: function(data) { var onlineNumList = data.obj.onlineNumList; //出勤数量 var attendanceNumList = data.obj.attendanceNumList; //当日考勤数量 var orgNameList = data.obj.orgNameList; //分公司名称 var onlineNums = data.obj.onlineNums; //在场总人数 var sysOnlineNums = data.obj.sysOnlineNums; //新系统在场人数 var attendanceNums = data.obj.attendanceNums; //考勤总人数 $("#onlineNums").html(onlineNums); $("#sysOnlineNums").html(sysOnlineNums); $("#attendanceNums").html(attendanceNums); sgryEcharts(onlineNumList, attendanceNumList, orgNameList, onlineNums, attendanceNums); } }); } /** * 管理人员数据获取 */ function findGlryEcharts() { $("#onlineNums").html("0"); $("#attendanceNums").html("0"); $.ajax({ type: 'POST', beforeSend: function(request) { request.setRequestHeader("token", token); }, url: smz_web_url + 'person/getManagerNum', data: { selfOrgId: selfOrgId }, dataType: "json", success: function(data) { var attendanceNumList = data.obj.attendanceNumList; //出勤数量 var onlineNumList = data.obj.onlineNumList; //在线数量 var sysOnlineNumList = data.obj.sysOnlineNumList; //系统在线数量 var orgNameList = data.obj.orgNameList; //分公司名称 var onlineNums = data.obj.onlineNums; //在场总人数 var sysOnlineNums = data.obj.sysOnlineNums; //在场总人数 var attendanceNums = data.obj.attendanceNums; //考勤总人数 $("#onlineNums").html(onlineNums); $("#sysOnlineNums").html(sysOnlineNums); $("#attendanceNums").html(attendanceNums); glryEcharts(onlineNumList, orgNameList, onlineNums, attendanceNums, attendanceNumList); } }); } var sgryInterval; var glryInterval; function ryglShowEcharts(data) { if (data == "1") { $("#sgryEcharts").css("display", "block"); $("#glryEcharts").css("display", "none"); document.getElementById("sgryBtn").style.backgroundColor = "#02A7F0"; document.getElementById("glryBtn").style.backgroundColor = "#027DB4"; findSgryEcharts() //人员管理-施工人员 clearInterval(glryInterval); } else { $("#sgryEcharts").css("display", "none"); $("#glryEcharts").css("display", "block"); document.getElementById("sgryBtn").style.backgroundColor = "#027DB4"; document.getElementById("glryBtn").style.backgroundColor = "#02A7F0"; findGlryEcharts(); //人员管理-管理人员 clearInterval(sgryInterval); } } /** * 风险管控数据获取 */ function findRiskEcharts() { $.ajax({ type: 'POST', beforeSend: function(request) { request.setRequestHeader("token", token); }, url: smz_web_url + 'risk/getRiskNum', data: { selfOrgId: selfOrgId }, dataType: "json", success: function(data) { var res = data.res; var total = 0; var num = 0; var mix = 0; if (res == "1") { var obj = data.obj; total = obj.greenRisk.total; num = obj.greenRisk.num; mix = obj.greenRisk.mix; greenEcharts(total, num, mix); total = obj.yellowRisk.total; num = obj.yellowRisk.num; mix = obj.yellowRisk.mix; yellowEcharts(total, num, mix); total = obj.redRisk.total; num = obj.redRisk.num; mix = obj.redRisk.mix; redEcharts(total, num, mix); } else { greenEcharts(total, num, mix); yellowEcharts(total, num, mix); redEcharts(total, num, mix); } } }); } /** * 作业票数据获取 */ function findZypEcharts() { $.ajax({ type: 'POST', beforeSend: function(request) { request.setRequestHeader("token", token); }, url: smz_web_url + 'ticket/getTicketNum', data: { selfOrgId: selfOrgId }, dataType: "json", success: function(data) { var companyName = data.obj.companyName; //分公司名称 var reviewed = data.obj.reviewed; //未完结 var finished = data.obj.finished; //已完结 var total = data.obj.total; //总数 zypEcharts(companyName, reviewed, finished, total); } }); } //风险管控-页面跳转 function showRisk() { localStorage.setItem('token', token); localStorage.setItem("statistics_proName", ""); localStorage.setItem("statistics_riskName", ""); var index = top.layer.open({ title: false, type: 2, content: '../../page/security/risk.html', area: ['90%', '90%'], maxmin: false }); } //作业票-页面跳转 function showZyp(orgName) { localStorage.setItem("orgName", orgName); var height = '800px'; var width = '1400px'; localStorage.setItem('token', token); var index = top.layer.open({ title: false, type: 2, content: '../../page/security/workTicket.html', area: ['90%', '90%'], maxmin: false }); } //项目概况 function xmgkEcharts(vol, bd, xl) { var myChart = echarts.init(document.getElementById('xmgkDiv')); var img = [ 'image://', 'image://', 'image://', 'image://', ]; var option = { tooltip: { trigger: 'axis', axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' } }, grid: { left: '8%', top: '27%', bottom: '12%', right: '5%', }, legend: { x: '35%', top: '12%', textStyle: { color: '#fff', }, data: ['线路', '变电'] }, yAxis: [{ type: 'value', position: 'left', nameTextStyle: { color: '#00FFFF' }, splitLine: { show: false, }, axisLine: { show: true }, axisTick: { show: false }, axisLabel: { formatter: '{value}', color: '#fff', fontSize: 12 } }, ], xAxis: [{ type: 'category', axisTick: { show: false }, axisLine: { show: true, }, axisLabel: { inside: false, interval: 0, textStyle: { color: '#fff', // x轴颜色 fontWeight: 'normal', fontSize: '14', lineHeight: 22 }, formatter: function(value) { return value; } }, data: vol, }, ], //滚动条 dataZoom: [{ show: false, height: 12, xAxisIndex: [0], bottom: '0%', start: 1, end: 80, zoomLock: true, //禁用缩放 handleSize: '110%', handleStyle: { color: "#d3dee5", }, textStyle: { color: "#fff" }, borderColor: "#90979c" }], series: [ /* { name: "线路", symbolSize: 150, symbol: img[2], type: "line", data: xl, itemStyle: { normal: { borderWidth: 5, color: '#13DDF5', } }, label: { show: true, position: 'inside', textStyle: { color: '#fff', } }, areaStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'rgba(19,221,245,0.3)' }, { offset: 1, color: 'rgba(19,221,245,0)' } ], false), shadowColor: 'rgba(19,221,245, 0.9)', shadowBlur: 20 } } }, { name: "变电", symbolSize: 150, symbol: img[3], type: "line", data: bd, itemStyle: { normal: { borderWidth: 5, color: '#7ECDAA', } }, label: { show: true, position: 'inside', textStyle: { color: '#fff', } }, areaStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'rgba(126,205,170,0.3)' }, { offset: 1, color: 'rgba(126,205,170,0)' } ], false), shadowColor: 'rgba(126,205,170, 0.9)', shadowBlur: 20 } } }, */ /* 优化:原图片太大,导致点击不准,将图片改为echart图标 */ { name: '线路', type: 'line', showAllSymbol: true, symbol: 'circle', symbolSize: 12, lineStyle: { normal: { color: "#2CC191", shadowColor: 'rgba(0, 0, 0, .3)', shadowBlur: 0, shadowOffsetY: 5, shadowOffsetX: 5, }, }, label: { show: true, position: 'top', textStyle: { color: '#2CC191', } }, itemStyle: { color: "#2CC191", borderColor: "#fff", borderWidth: 3, shadowColor: 'rgba(0, 0, 0, .3)', shadowBlur: 0, shadowOffsetY: 2, shadowOffsetX: 2, }, tooltip: { show: false }, areaStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'rgba(108,80,243,0.3)' }, { offset: 1, color: 'rgba(108,80,243,0)' } ], false), shadowColor: 'rgba(108,80,243, 0.9)', shadowBlur: 20 } }, data: xl }, { name: '变电', type: 'line', showAllSymbol: true, symbol: 'circle', symbolSize: 12, lineStyle: { normal: { color: "#FAEE52", shadowColor: 'rgba(0, 0, 0, .3)', shadowBlur: 0, shadowOffsetY: 5, shadowOffsetX: 5, }, }, label: { show: true, position: 'top', textStyle: { color: '#FAEE52', } }, itemStyle: { color: "#FAEE52", borderColor: "#fff", borderWidth: 3, shadowColor: '#FAEE52', shadowBlur: 0, shadowOffsetY: 2, shadowOffsetX: 2, }, tooltip: { show: false }, areaStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: 'rgba(250,238,82,0.3)' }, { offset: 1, color: 'rgba(250,238,82,0)' } ], false), shadowColor: 'rgba(250,238,82, 0.9)', shadowBlur: 20 } }, data: bd, } ], }; var startNum = 0; var endNum = 80; window.setInterval(function() { if (endNum > 100) { option.dataZoom[0].start = 0; option.dataZoom[0].end = 80; startNum = 0; endNum = 80; // 为echarts对象加载数据 myChart.setOption(option); //防止重复触发点击事件 if (myChart._$handlers.click) { myChart._$handlers.click.length = 0; } myChart.on('click', function(params) { console.log("params", params); var voltageLevel = params.name; //电压等级 var proType = params.seriesName; //工程类别 openProPage(voltageLevel, proType); }); } else { option.dataZoom[0].start = startNum; option.dataZoom[0].end = endNum; // 为echarts对象加载数据 myChart.setOption(option); //防止重复触发点击事件 if (myChart._$handlers.click) { myChart._$handlers.click.length = 0; } myChart.on('click', function(params) { console.log("params", params); var voltageLevel = params.name; //电压等级 var proType = params.seriesName; //工程类别 openProPage(voltageLevel, proType); }); } startNum += 10; endNum += 10; }, intervalTime); // 为echarts对象加载数据 myChart.setOption(option); myChart.on('click', function(params) { console.log("params", params); var voltageLevel = params.name; //电压等级 var proType = params.seriesName; //工程类别 openProPage(voltageLevel, proType); }); } //人员管理-施工人员 function sgryEcharts(onlineNumList, attendanceNumList, orgNameList, onlineNums, attendanceNums) { var myChart = echarts.init(document.getElementById('sgryEcharts')); var option = { grid: { left: '5%', right: '7%', bottom: '1%', top: '7%', containLabel: true }, tooltip: { trigger: 'axis', axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' } }, xAxis: { show: false, type: 'value' }, yAxis: [{ type: 'category', inverse: true, axisLabel: { show: true, textStyle: { color: '#fff' }, }, splitLine: { show: false }, axisTick: { show: false }, axisLine: { show: false }, data: orgNameList }], //滚动条 dataZoom: [{ show: false, height: 12, yAxisIndex: [0], bottom: '0%', start: 1, end: 40, zoomLock: true, //禁用缩放 handleSize: '110%', handleStyle: { color: "#d3dee5", }, textStyle: { color: "#fff" }, borderColor: "#90979c" }], series: [{ name: '在线人数', type: 'bar', stack: 'Tik Tok', zlevel: 1, itemStyle: { normal: { barBorderRadius: 30, color: function(params) { var index = params.dataIndex; var color1 = ['#FF7F9A', '#F6E2A3', '#37AEFC', '#E6915E', '#FF7F9A', '#F6E2A3', '#37AEFC', '#E6915E', '#FF7F9A', '#F6E2A3', '#37AEFC', '#E6915E' ]; return color1[index]; }, } }, label: { normal: { show: false, position: 'insideRight', offset: [18, 0], textStyle: { align: 'center', baseline: 'middle', fontSize: 14, fontWeight: '400', color: function(params) { var index = params.dataIndex; var color1 = ['#FF7F9A', '#F6E2A3', '#37AEFC', '#E6915E']; return color1[index]; }, textShadowColor: '#000', textShadowBlur: '0', textShadowOffsetX: 1, textShadowOffsetY: 1, } }, }, barWidth: 15, data: onlineNumList }, { name: '今日考勤人数', type: 'bar', stack: 'Tik Tok', zlevel: 1, itemStyle: { normal: { barBorderRadius: 15, color: '#A8FBC8' }, }, label: { normal: { show: false, position: 'insideRight', offset: [18, 0], textStyle: { align: 'center', baseline: 'middle', fontSize: 14, fontWeight: '400', color: '#A8FBC8', textShadowColor: '#000', textShadowBlur: '0', textShadowOffsetX: 1, textShadowOffsetY: 1, } }, }, barWidth: 15, data: attendanceNumList } ] }; var startNum = 0; var endNum = 40; clearInterval(sgryInterval); sgryInterval = window.setInterval(function() { zoomInterval(); }, intervalTime); function zoomInterval() { if (endNum > 100) { option.dataZoom[0].start = 0; option.dataZoom[0].end = 40; startNum = 0; endNum = 40; // 为echarts对象加载数据 myChart.setOption(option); //防止重复触发点击事件 if (myChart._$handlers.click) { myChart._$handlers.click.length = 0; } myChart.on('click', function(params) { var name = params.name; var value = params.value; opensgryPerson(name, value); }); } else { option.dataZoom[0].start = startNum; option.dataZoom[0].end = endNum; // 为echarts对象加载数据 myChart.setOption(option); //防止重复触发点击事件 if (myChart._$handlers.click) { myChart._$handlers.click.length = 0; } myChart.on('click', function(params) { var name = params.name; var value = params.value; opensgryPerson(name, value); }); } startNum += 20; endNum += 20; }; // 为echarts对象加载数据 myChart.setOption(option); myChart.on('click', function(params) { var name = params.name; var value = params.value; opensgryPerson(name, value); }); } //人员管理-管理人员 function glryEcharts(onlineNumList, orgNameList, onlineNums, attendanceNums, attendanceNumList) { var myChart = echarts.init(document.getElementById('glryEcharts')); var option = { grid: { left: '5%', right: '7%', bottom: '1%', top: '7%', containLabel: true }, tooltip: { trigger: 'axis', axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' } }, xAxis: { show: false, type: 'value' }, yAxis: [{ type: 'category', inverse: true, axisLabel: { show: true, textStyle: { color: '#fff' }, }, splitLine: { show: false }, axisTick: { show: false }, axisLine: { show: false }, data: orgNameList }], //滚动条 dataZoom: [{ show: false, height: 12, yAxisIndex: [0], bottom: '0%', start: 1, end: 20, zoomLock: true, //禁用缩放 handleSize: '110%', handleStyle: { color: "#d3dee5", }, textStyle: { color: "#fff" }, borderColor: "#90979c" }], series: [{ name: '在线人数', type: 'bar', stack: 'Tik Tok', zlevel: 1, itemStyle: { normal: { barBorderRadius: 30, color: function(params) { var index = params.dataIndex; var color1 = ['#FF7F9A', '#F6E2A3', '#37AEFC', '#E6915E', '#FF7F9A', '#F6E2A3', '#37AEFC', '#E6915E', '#FF7F9A', '#F6E2A3', '#37AEFC', '#E6915E' ]; return color1[index]; }, } }, label: { normal: { show: false, position: 'insideRight', offset: [18, 0], textStyle: { align: 'center', baseline: 'middle', fontSize: 14, fontWeight: '400', color: function(params) { var index = params.dataIndex; var color1 = ['#FF7F9A', '#F6E2A3', '#37AEFC', '#E6915E']; return color1[index]; }, textShadowColor: '#000', textShadowBlur: '0', textShadowOffsetX: 1, textShadowOffsetY: 1, } }, }, barWidth: 15, data: onlineNumList }, { name: '今日考勤人数', type: 'bar', stack: 'Tik Tok', zlevel: 1, itemStyle: { normal: { barBorderRadius: 15, color: '#A8FBC8' }, }, label: { normal: { show: false, position: 'insideRight', offset: [18, 0], textStyle: { align: 'center', baseline: 'middle', fontSize: 14, fontWeight: '400', color: '#A8FBC8', textShadowColor: '#000', textShadowBlur: '0', textShadowOffsetX: 1, textShadowOffsetY: 1, } }, }, barWidth: 15, data: attendanceNumList } ] }; var startNum = 0; var endNum = 40; clearInterval(glryInterval); glryInterval = window.setInterval(function() { zoomInterval(); }, intervalTime); function zoomInterval() { if (endNum > 100) { option.dataZoom[0].start = 0; option.dataZoom[0].end = 40; startNum = 0; endNum = 40; // 为echarts对象加载数据 myChart.setOption(option); //防止重复触发点击事件 if (myChart._$handlers.click) { myChart._$handlers.click.length = 0; } myChart.on('click', function(params) { var name = params.name; var value = params.value; openglryPerson(name, value); }); } else { option.dataZoom[0].start = startNum; option.dataZoom[0].end = endNum; // 为echarts对象加载数据 myChart.setOption(option); //防止重复触发点击事件 if (myChart._$handlers.click) { myChart._$handlers.click.length = 0; } myChart.on('click', function(params) { var name = params.name; var value = params.value; openglryPerson(name, value); }); } startNum += 20; endNum += 20; }; // 为echarts对象加载数据 myChart.setOption(option); myChart.on('click', function(params) { var name = params.name; var value = params.value; openglryPerson(name, value); }); } /** * 工程概况 二级页面 */ function openProPage(voltageLevel, proType) { localStorage.setItem('voltageLevel', voltageLevel); localStorage.setItem('proType', proType); var index = top.layer.open({ title: false, type: 2, content: '../../page/index/pro.html', area: ['90%', '90%'], maxmin: false, cancel: function() { top.layer.closeAll(); } }); } /** * 人员管理 二级页面施工人员 */ function opensgryPerson(name, value) { localStorage.setItem('name', name); localStorage.setItem('value', value); var index = top.layer.open({ title: false, type: 2, content: '../../page/person/construction/person.html', area: ['90%', '90%'], maxmin: false, cancel: function() { top.layer.closeAll(); } }); } /** * 人员管理 二级页面管理人员 */ function openglryPerson(name, value) { localStorage.setItem('name', name); localStorage.setItem('value', value); var index = top.layer.open({ title: false, type: 2, content: '../../page/person/administration/person.html', area: ['90%', '90%'], maxmin: false, cancel: function() { top.layer.closeAll(); } }); } //风险-绿 function greenEcharts(total, num, mix) { var myChart = echarts.init(document.getElementById('greenDiv')); let angle = 0; //角度,用来做简单的动画效果的 let value = 70; var timerId; var option = { tooltip: { trigger: 'axis', axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' } }, title: { text: '绿色风险', left: '50%', top: '88%', textAlign: 'center', textStyle: { fontWeight: 'normal', fontSize: '20', color: '#fff', textAlign: 'center', }, }, series: [ // 紫色 { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.6, startAngle: (0 + angle) * Math.PI / 180, endAngle: (90 + angle) * Math.PI / 180 }, style: { stroke: "#8383FA", fill: "transparent", lineWidth: 1.5 }, silent: true }; }, data: [0] }, { name: "ring5", //紫点 type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { let x0 = api.getWidth() / 2; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.6; let point = getCirlPoint(x0, y0, r, (90 + angle)) return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: "#8450F9", //绿 fill: "#8450F9" }, silent: true }; }, data: [0] }, // 蓝色 { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.6, startAngle: (180 + angle) * Math.PI / 180, endAngle: (270 + angle) * Math.PI / 180 }, style: { stroke: "#4386FA", fill: "transparent", lineWidth: 1.5 }, silent: true }; }, data: [0] }, { name: "ring5", // 蓝色 type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { let x0 = api.getWidth() / 2; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.6; let point = getCirlPoint(x0, y0, r, (180 + angle)) return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: "#4386FA", //绿 fill: "#4386FA" }, silent: true }; }, data: [0] }, { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.65, startAngle: (270 + -angle) * Math.PI / 180, endAngle: (40 + -angle) * Math.PI / 180 }, style: { stroke: "#0CD3DB", fill: "transparent", lineWidth: 1.5 }, silent: true }; }, data: [0] }, // 橘色 { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.65, startAngle: (90 + -angle) * Math.PI / 180, endAngle: (220 + -angle) * Math.PI / 180 }, style: { stroke: "#FF8E89", fill: "transparent", lineWidth: 1.5 }, silent: true }; }, data: [0] }, { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { let x0 = api.getWidth() / 2; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.65; let point = getCirlPoint(x0, y0, r, (90 + -angle)) return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: "#FF8E89", //粉 fill: "#FF8E89" }, silent: true }; }, data: [0] }, { name: "ring5", //绿点 type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { let x0 = api.getWidth() / 2; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.65; let point = getCirlPoint(x0, y0, r, (270 + -angle)) return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: "#0CD3DB", //绿 fill: "#0CD3DB" }, silent: true }; }, data: [0] }, { type: 'pie', radius: ['72%', '54%'], silent: true, clockwise: true, startAngle: 90, z: 0, zlevel: 0, label: { normal: { position: "center", } }, data: [{ value: mix, name: "", itemStyle: { normal: { color: { // 完成的圆环的颜色 colorStops: [{ offset: 0, color: '#A098FC' // 0% 处的颜色 }, { offset: 0.3, color: '#4386FA' // 0% 处的颜色 }, { offset: 0.6, color: '#4FADFD' // 0% 处的颜色 }, { offset: 0.8, color: '#0CD3DB' // 100% 处的颜色 }, { offset: 1, color: '#646CF9' // 100% 处的颜色 } ] }, } } }, { value: 100 - mix, name: "", label: { normal: { show: false } }, itemStyle: { normal: { color: "#173164" } } } ] }, { type: 'pie', radius: ['42%', '45%'], silent: true, clockwise: true, startAngle: 270, z: 0, zlevel: 0, label: { normal: { position: "center", } }, data: [{ value: mix, name: "", itemStyle: { normal: { color: { // 完成的圆环的颜色 colorStops: [{ offset: 0, color: '#00EDF3' // 0% 处的颜色 }, { offset: 1, color: '#646CF9' // 100% 处的颜色 }] }, } } }, { value: mix, //赋值 label: { formatter: '{c}%', position: 'center', show: true, textStyle: { fontSize: '18', fontWeight: 'normal', color: '#29EEF3' } }, itemStyle: { normal: { color: "#173164" } } } ] }, ] }; //获取圆上面某点的坐标(x0,y0表示坐标,r半径,angle角度) function getCirlPoint(x0, y0, r, angle) { let x1 = x0 + r * Math.cos(angle * Math.PI / 180) let y1 = y0 + r * Math.sin(angle * Math.PI / 180) return { x: x1, y: y1 } } function draw() { angle = angle + 3 myChart.setOption(option, true) //window.requestAnimationFrame(draw); } if (timerId) { clearInterval(timerId); } timerId = setInterval(function() { //用setInterval做动画感觉有问题 draw() }, 100); // 为echarts对象加载数据 myChart.setOption(option); } //风险-黄 function yellowEcharts(total, num, mix) { var myChart = echarts.init(document.getElementById('yellowDiv')); let angle = 0; //角度,用来做简单的动画效果的 let value = 80; var timerId; var option = { title: { text: '黄色风险', left: '50%', top: '88%', textAlign: 'center', textStyle: { fontWeight: 'normal', fontSize: '20', color: '#fff', textAlign: 'center', }, }, series: [ // 紫色 { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.6, startAngle: (0 + angle) * Math.PI / 180, endAngle: (90 + angle) * Math.PI / 180 }, style: { stroke: "#8383FA", fill: "transparent", lineWidth: 1.5 }, silent: true }; }, data: [0] }, { name: "ring5", //紫点 type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { let x0 = api.getWidth() / 2; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.6; let point = getCirlPoint(x0, y0, r, (90 + angle)) return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: "#8450F9", //绿 fill: "#8450F9" }, silent: true }; }, data: [0] }, // 蓝色 { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.6, startAngle: (180 + angle) * Math.PI / 180, endAngle: (270 + angle) * Math.PI / 180 }, style: { stroke: "#4386FA", fill: "transparent", lineWidth: 1.5 }, silent: true }; }, data: [0] }, { name: "ring5", // 蓝色 type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { let x0 = api.getWidth() / 2; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.6; let point = getCirlPoint(x0, y0, r, (180 + angle)) return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: "#4386FA", //绿 fill: "#4386FA" }, silent: true }; }, data: [0] }, { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.65, startAngle: (270 + -angle) * Math.PI / 180, endAngle: (40 + -angle) * Math.PI / 180 }, style: { stroke: "#0CD3DB", fill: "transparent", lineWidth: 1.5 }, silent: true }; }, data: [0] }, // 橘色 { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.65, startAngle: (90 + -angle) * Math.PI / 180, endAngle: (220 + -angle) * Math.PI / 180 }, style: { stroke: "#FF8E89", fill: "transparent", lineWidth: 1.5 }, silent: true }; }, data: [0] }, { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { let x0 = api.getWidth() / 2; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.65; let point = getCirlPoint(x0, y0, r, (90 + -angle)) return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: "#FF8E89", //粉 fill: "#FF8E89" }, silent: true }; }, data: [0] }, { name: "ring5", //绿点 type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { let x0 = api.getWidth() / 2; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.65; let point = getCirlPoint(x0, y0, r, (270 + -angle)) return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: "#0CD3DB", //绿 fill: "#0CD3DB" }, silent: true }; }, data: [0] }, { type: 'pie', radius: ['72%', '54%'], silent: true, clockwise: true, startAngle: 90, z: 0, zlevel: 0, label: { normal: { position: "center", } }, data: [{ value: mix, name: "", itemStyle: { normal: { color: { // 完成的圆环的颜色 colorStops: [{ offset: 0, color: '#A098FC' // 0% 处的颜色 }, { offset: 0.3, color: '#4386FA' // 0% 处的颜色 }, { offset: 0.6, color: '#4FADFD' // 0% 处的颜色 }, { offset: 0.8, color: '#0CD3DB' // 100% 处的颜色 }, { offset: 1, color: '#646CF9' // 100% 处的颜色 } ] }, } } }, { value: 100 - mix, name: "", label: { normal: { show: false } }, itemStyle: { normal: { color: "#173164" } } } ] }, { type: 'pie', radius: ['42%', '45%'], silent: true, clockwise: true, startAngle: 270, z: 0, zlevel: 0, label: { normal: { position: "center", } }, data: [{ value: mix, name: "", itemStyle: { normal: { color: { // 完成的圆环的颜色 colorStops: [{ offset: 0, color: '#00EDF3' // 0% 处的颜色 }, { offset: 1, color: '#646CF9' // 100% 处的颜色 }] }, } } }, { value: mix, label: { formatter: '{c}%', position: 'center', show: true, textStyle: { fontSize: '18', fontWeight: 'normal', color: '#29EEF3' } }, itemStyle: { normal: { color: "#173164" } } } ] }, ] }; //获取圆上面某点的坐标(x0,y0表示坐标,r半径,angle角度) function getCirlPoint(x0, y0, r, angle) { let x1 = x0 + r * Math.cos(angle * Math.PI / 180) let y1 = y0 + r * Math.sin(angle * Math.PI / 180) return { x: x1, y: y1 } } function draw() { angle = angle + 3 myChart.setOption(option, true) //window.requestAnimationFrame(draw); } if (timerId) { clearInterval(timerId); } timerId = setInterval(function() { //用setInterval做动画感觉有问题 draw() }, 100); // 为echarts对象加载数据 myChart.setOption(option); } //风险-红 function redEcharts(total, num, mix) { var myChart = echarts.init(document.getElementById('redDiv')); let angle = 0; //角度,用来做简单的动画效果的 let value = 80; var timerId; var option = { tooltip: { trigger: 'axis', axisPointer: { // 坐标轴指示器,坐标轴触发有效 type: 'shadow' // 默认为直线,可选为:'line' | 'shadow' } }, title: { text: '红色风险', left: '50%', top: '88%', textAlign: 'center', textStyle: { fontWeight: 'normal', fontSize: '20', color: '#fff', textAlign: 'center', }, }, series: [ // 紫色 { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.6, startAngle: (0 + angle) * Math.PI / 180, endAngle: (90 + angle) * Math.PI / 180 }, style: { stroke: "#8383FA", fill: "transparent", lineWidth: 1.5 }, silent: true }; }, data: [0] }, { name: "ring5", //紫点 type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { let x0 = api.getWidth() / 2; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.6; let point = getCirlPoint(x0, y0, r, (90 + angle)) return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: "#8450F9", //绿 fill: "#8450F9" }, silent: true }; }, data: [0] }, // 蓝色 { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.6, startAngle: (180 + angle) * Math.PI / 180, endAngle: (270 + angle) * Math.PI / 180 }, style: { stroke: "#4386FA", fill: "transparent", lineWidth: 1.5 }, silent: true }; }, data: [0] }, { name: "ring5", // 蓝色 type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { let x0 = api.getWidth() / 2; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.6; let point = getCirlPoint(x0, y0, r, (180 + angle)) return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: "#4386FA", //绿 fill: "#4386FA" }, silent: true }; }, data: [0] }, { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.65, startAngle: (270 + -angle) * Math.PI / 180, endAngle: (40 + -angle) * Math.PI / 180 }, style: { stroke: "#0CD3DB", fill: "transparent", lineWidth: 1.5 }, silent: true }; }, data: [0] }, // 橘色 { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { return { type: 'arc', shape: { cx: api.getWidth() / 2, cy: api.getHeight() / 2, r: Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.65, startAngle: (90 + -angle) * Math.PI / 180, endAngle: (220 + -angle) * Math.PI / 180 }, style: { stroke: "#FF8E89", fill: "transparent", lineWidth: 1.5 }, silent: true }; }, data: [0] }, { name: "ring5", type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { let x0 = api.getWidth() / 2; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.65; let point = getCirlPoint(x0, y0, r, (90 + -angle)) return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: "#FF8E89", //粉 fill: "#FF8E89" }, silent: true }; }, data: [0] }, { name: "ring5", //绿点 type: 'custom', coordinateSystem: "none", renderItem: function(params, api) { let x0 = api.getWidth() / 2; let y0 = api.getHeight() / 2; let r = Math.min(api.getWidth(), api.getHeight()) / 1.4 * 0.65; let point = getCirlPoint(x0, y0, r, (270 + -angle)) return { type: 'circle', shape: { cx: point.x, cy: point.y, r: 4 }, style: { stroke: "#0CD3DB", //绿 fill: "#0CD3DB" }, silent: true }; }, data: [0] }, { type: 'pie', radius: ['72%', '54%'], silent: true, clockwise: true, startAngle: 90, z: 0, zlevel: 0, label: { normal: { position: "center", } }, data: [{ value: mix, name: "", itemStyle: { normal: { color: { // 完成的圆环的颜色 colorStops: [{ offset: 0, color: '#A098FC' // 0% 处的颜色 }, { offset: 0.3, color: '#4386FA' // 0% 处的颜色 }, { offset: 0.6, color: '#4FADFD' // 0% 处的颜色 }, { offset: 0.8, color: '#0CD3DB' // 100% 处的颜色 }, { offset: 1, color: '#646CF9' // 100% 处的颜色 } ] }, } } }, { value: 100 - mix, name: "", label: { normal: { show: false } }, itemStyle: { normal: { color: "#173164" } } } ] }, { type: 'pie', radius: ['42%', '45%'], silent: true, clockwise: true, startAngle: 270, z: 0, zlevel: 0, label: { normal: { position: "center", } }, data: [{ value: mix, name: "", itemStyle: { normal: { color: { // 完成的圆环的颜色 colorStops: [{ offset: 0, color: '#00EDF3' // 0% 处的颜色 }, { offset: 1, color: '#646CF9' // 100% 处的颜色 }] }, } } }, { value: mix, label: { formatter: '{c}%', position: 'center', show: true, textStyle: { fontSize: '18', fontWeight: 'normal', color: '#29EEF3' } }, itemStyle: { normal: { color: "#173164" } } } ] }, ] }; //获取圆上面某点的坐标(x0,y0表示坐标,r半径,angle角度) function getCirlPoint(x0, y0, r, angle) { let x1 = x0 + r * Math.cos(angle * Math.PI / 180) let y1 = y0 + r * Math.sin(angle * Math.PI / 180) return { x: x1, y: y1 } } function draw() { angle = angle + 3 myChart.setOption(option, true) //window.requestAnimationFrame(draw); } if (timerId) { clearInterval(timerId); } timerId = setInterval(function() { //用setInterval做动画感觉有问题 draw() }, 100); // 为echarts对象加载数据 myChart.setOption(option); } //工程造价 function proMoneyEcharts() { $.ajax({ type: 'POST', beforeSend: function(request) { request.setRequestHeader("token", token); }, url: smz_web_url + 'costProgressPayment/getProgressNum', dataType: "json", data: { selfOrgId: selfOrgId, proId: "no" }, success: function(data) { console.log("data", data); initProMoneyEcharts(data); }, error: function(err) { progressIndex = 0; } }); } var jj; function initProMoneyEcharts(data) { var proList = data.obj.proList; var len = proList.length; var start = 1; var end = 80; var progress = 20; if (len > 4) { end = 4 / len * 100; progress = (100 - end) / (len - 4); } console.log("len", len); console.log("start", start); console.log("end", end); console.log("progress", progress); var amountList = data.obj.amountList; var finishAmountList = data.obj.finishAmountList; var progressList = data.obj.progressList; var myChart = echarts.init(document.getElementById('proMoney')); var option = { tooltip: { trigger: "axis", axisPointer: { type: "shadow", label: { show: false, color: 'fff' } } }, grid: { left: "10%", top: "30%", right: "10%", bottom: "10%" }, legend: { data: ["总数", "已完成金额", "已完成百分比"], top: "9%", textStyle: { color: "#fff", fontSize: 14 } }, xAxis: { data: proList, axisLine: { show: true, //隐藏X轴轴线 lineStyle: { color: "#3d5269", width: 1 } }, axisTick: { show: true, //隐藏X轴刻度 alignWithLabel: true }, axisLabel: { show: true, interval: 0, textStyle: { color: "#fff", //X轴文字颜色 fontSize: 14 }, formatter: function(value) { var len = value.length; return value.substring(0, 4) + "..." + value.substring(len - 5, len); } } }, yAxis: [{ type: "value", nameTextStyle: { color: "#fff", fontSize: 14 }, splitLine: { show: false, }, axisTick: { show: false }, axisLine: { show: true, lineStyle: { width: 1, color: "#3d5269" } }, axisLabel: { show: true, textStyle: { color: "#fff", fontSize: 14 } } }, { type: "value", nameTextStyle: { color: "#fff", fontSize: 14 }, position: "right", splitLine: { show: false }, axisTick: { show: false }, axisLine: { show: true, lineStyle: { color: "#396A87", width: 1 } }, axisLabel: { show: true, formatter: "{value} %", //右侧Y轴文字显示 textStyle: { color: "#fff", fontSize: 14 } } } ], //滚动条 dataZoom: [{ show: false, height: 12, xAxisIndex: [0], bottom: '0%', start: start, end: end, zoomLock: true, //禁用缩放 handleSize: '110%', handleStyle: { color: "#d3dee5", }, textStyle: { color: "#fff" }, borderColor: "#90979c" }], series: [{ name: "总数", type: "bar", barWidth: 18, label: { show: true, position: 'top', textStyle: { color: '#fff', } }, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: "#F2F1A3" }, { offset: 1, color: "#FFFFF3" } ]) } }, data: amountList }, { name: "已完成金额", type: "bar", barWidth: 18, label: { show: true, position: 'top', textStyle: { color: '#fff', } }, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{ offset: 0, color: "#1CFFF4" }, { offset: 1, color: "#D5FFFD" } ]) } }, data: finishAmountList }, { name: "已完成百分比", type: "line", yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 showAllSymbol: true, //显示所有图形。 symbol: "pin", //标记的图形为实心圆 symbolSize: 30, itemStyle: { //折线拐点标志的样式 color: "#FFA4A4", borderColor: "#FFA4A4", width: 2, shadowColor: "#FFA4A4", shadowBlur: 2 }, lineStyle: { color: "#FFA4A4", width: 2, shadowBlur: 2 }, label: { show: true, offset: [0, 22], color: '#fff' }, data: progressList } ] } var startNum = start; var endNum = end; jj = window.setInterval(function() { if (endNum > 100) { option.dataZoom[0].start = start; option.dataZoom[0].end = end; startNum = start; endNum = end; // 为echarts对象加载数据 myChart.setOption(option); //防止重复触发点击事件 if (myChart._$handlers.click) { myChart._$handlers.click.length = 0; } myChart.on('click', function(params) { console.log("params", params); var proName = params.name; localStorage.setItem("index_proName", proName); var index = top.layer.open({ title: false, type: 2, content: '../../page/cost/progressFundAppropriationMge.html', area: ['90%', '90%'], maxmin: false }); }); } else { option.dataZoom[0].start = startNum; option.dataZoom[0].end = endNum; // 为echarts对象加载数据 myChart.setOption(option); //防止重复触发点击事件 if (myChart._$handlers.click) { myChart._$handlers.click.length = 0; } myChart.on('click', function(params) { console.log("params", params); var proName = params.name; localStorage.setItem("index_proName", proName); var index = top.layer.open({ title: false, type: 2, content: '../../page/cost/progressFundAppropriationMge.html', area: ['90%', '90%'], maxmin: false }); }); } startNum += progress; endNum += progress; }, intervalTime); //为echarts对象加载数据 myChart.setOption(option); myChart.on('click', function(params) { console.log("params", params); var proName = params.name; localStorage.setItem("index_proName", proName); var index = top.layer.open({ title: false, type: 2, content: '../../page/cost/progressFundAppropriationMge.html', area: ['90%', '90%'], maxmin: false }); }); } //安全检查 function aqjcPhoto() { $.ajax({ type: "post", url: smz_web_url + "scheck/getCurrentPhoto", data: { token: token, selfOrgId: selfOrgId }, dataType: "json", success: function(data) { $("#WorkPhoto").empty(); if (data.res == "1") { var results = data.obj; var html = ""; if (results != null && results.length > 0) { if (results.length >= 6) { for (var i = 0; i < results.length; i += 6) { var num = results.length - i; if (num >= 6) { var path = results[i].photoType; var path2 = results[i + 1].photoType; var path3 = results[i + 2].photoType; var path4 = results[i + 3].photoType; var path5 = results[i + 4].photoType; var path6 = results[i + 5].photoType; if (i == 0) { html += "