hn_cloud_web/smz-screen/js/index/index.js

2814 lines
72 KiB
JavaScript
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

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: dataUrl + '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 = '<span id="plan_span">计划进度<label style="color:rgb(238, 157, 69);position: relative;top: -20px;left: 27px;">' +
plan_span + '%</label></span>';
} else {
html1 = '<span id="plan_span">计划进度<label style="color:rgb(238, 157, 69);">' + plan_span + '%</label></span>';
}
$("#secondDiv").append(html1);
var html2 = "";
if (actual >= 13 && actual < 87) {
html2 = '<span id="actual_span" style="top: 16px;">实际进度<label style="color:rgb(69, 238, 164);">' + actual_span +
'%</label></span>';
} else if (actual >= 87) {
var html =
'<span id="actual_span" style="left: -280px;right:0px;top: 16px;">实际进度<label style="color:rgb(69, 238, 164);">' +
actual_span + '%</label></span>';
$("#contentDiv").append(html);
} else if (actual < 13) {
var html =
'<span id="actual_span" style="left: -280px;right:0px;top: 16px;">实际进度<label style="color:rgb(69, 238, 164);">' +
actual_span + '%</label></span>';
$("#contentDiv").append(html);
}
$("#fristDiv").append(html2);
} else {
actual = parseFloat(actual);
plan = 0;
$("#fristDiv").css("width", actual + "%");
$("#secondDiv").css("width", plan + "%");
var html3 = '<span id="plan_span" style="top:-220%;right:0px;">计划进度<label style="color:rgb(238, 157, 69);">' +
plan_span + '%</label></span>';
$("#contentDiv").append(html3);
var html2 = "";
if (actual >= 13 && actual < 87) {
html2 = '<span id="actual_span" style="top: 16px;">实际进度<label style="color:rgb(69, 238, 164);">' + actual_span +
'%</label></span>';
} else if (actual >= 87) {
var html =
'<span id="actual_span" style="left: 200px;right:0px;top: 1px;">实际进度<label style="color:rgb(69, 238, 164);">' +
actual_span + '%</label></span>';
$("#contentDiv").append(html);
} else if (actual < 13) {
var html =
'<span id="actual_span" style="left: -280px;right:0px;top: 16px;">实际进度<label style="color:rgb(69, 238, 164);">' +
actual_span + '%</label></span>';
$("#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: dataUrl + '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: dataUrl + '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: dataUrl + '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: dataUrl + '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: dataUrl + '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: dataUrl + '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: dataUrl + "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 += "<div class='item active' style='width: 100%;height:100%;margin-left: 2%;margin-top: 1%'>";
html += '<img src=\"' + path +
'"\ onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
html += '<img src=\"' + path2 +
'"\ onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
html += '<img src=\"' + path3 +
'"\ onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
html += '<img src=\"' + path4 +
'"\ onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
html += '<img src=\"' + path5 +
'"\ onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
html += '<img src=\"' + path6 +
'"\ onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
html += "</div>";
} else {
html += "<div class='item' style='width: 100%;height:100%;margin-left: 2%;margin-top: 1%'>";
html += '<img src=\"' + path +
'"\" onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
html += '<img src=\"' + path2 +
'"\" onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
html += '<img src=\"' + path3 +
'"\" onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
html += '<img src=\"' + path4 +
'"\" onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
html += '<img src=\"' + path5 +
'"\" onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
html += '<img src=\"' + path6 +
'"\" onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
html += "</div>";
}
} else {
html += "<div class='item' style='width: 100%;height:100%;margin-left: 2%;margin-top: 1%'>";
for (var j = 0; j < num; j++) {
var ls = results[i + j];
var path = ls.photoType;
html += '<img src=\"' + path +
'"\" onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
}
html += "</div>";
}
}
} else {
html += "<div class='item active' style='width: 100%;height:100%;margin-left: 2%;'>";
for (var j = 0; j < results.length; j++) {
var l = results[j];
var path = l.photoType;
html += '<img src=\"' + path +
'"\" onerror="javascript:this.src=\'..\/..\/img\/home\/notPhoto.png\'" class="img" style="width: 30%;height:49%;float: left;margin: 1%;" />';
}
html += "</div>";
}
$("#WorkPhoto").append(html);
} else {
html +=
"<li class='center' style='color:#ffffff;list-style-type:none;text-align: center;margin-top: 22%;'>没有相关数据</li>";
}
$("#WorkPhoto").append(html);
}
},
error: function(XMLHttpRequest, textStatus, errorThrown) {}
});
}
//作业票
function zypEcharts(companyName, reviewed, finished, total) {
var myChart = echarts.init(document.getElementById('zypDiv'));
var option = {
tooltip: {
trigger: 'axis',
axisPointer: {
type: 'shadow'
}
},
legend: {
top: '10%',
textStyle: {
color: '#fff',
},
data: ['总数', '未完工', '已完工']
},
grid: {
top: '25%',
right: '3%',
left: '8%',
bottom: '12%'
},
xAxis: [{
type: 'category',
data: companyName,
axisLine: {
lineStyle: {
color: 'rgba(255,255,255,0.12)'
}
},
axisLabel: {
interval: 0,
margin: 10,
color: '#e2e9ff',
textStyle: {
fontSize: 14
},
},
}],
yAxis: [{
splitNumber: 3,
axisLabel: {
formatter: '{value}',
color: '#e2e9ff',
},
axisLine: {
show: true,
lineStyle: {
color: 'rgba(255,255,255,0.12)'
}
},
splitLine: {
show: false,
lineStyle: {
color: '#233e64'
}
},
}],
//滚动条
dataZoom: [{
show: false,
height: 12,
xAxisIndex: [0],
bottom: '0%',
start: 1,
end: 40,
zoomLock: true, //禁用缩放
handleSize: '110%',
handleStyle: {
color: "#d3dee5",
},
textStyle: {
color: "#fff"
},
borderColor: "#90979c"
}],
series: [{
name: '总数',
type: 'bar',
data: total,
barWidth: '15px',
itemStyle: {
normal: {
label: {
show: true,
position: 'top',
textStyle: {
color: '#fff'
}
},
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: '#67A8FF' // 0% 处的颜色
}, {
offset: 1,
color: '#88F4FE' // 100% 处的颜色
}], false),
barBorderRadius: [30, 30, 30, 30],
}
}
},
{
name: '未完工',
type: 'bar',
data: reviewed,
barWidth: '15px',
itemStyle: {
normal: {
label: {
show: true,
position: 'top',
textStyle: {
color: '#fff'
}
},
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: '#AAAD80' // 0% 处的颜色
}, {
offset: 1,
color: '#BBBAAA' // 100% 处的颜色
}], false),
barBorderRadius: [30, 30, 30, 30],
}
}
},
{
name: '已完工',
type: 'bar',
data: finished,
barWidth: '15px',
itemStyle: {
normal: {
label: {
show: true,
position: 'top',
textStyle: {
color: '#fff'
}
},
color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
offset: 0,
color: '#4CEA80' // 0% 处的颜色
}, {
offset: 1,
color: '#D6FECA' // 100% 处的颜色
}], false),
barBorderRadius: [30, 30, 30, 30],
}
}
}
]
};
var startNum = 0;
var endNum = 40;
window.setInterval(function() {
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 type = params.seriesName;
console.log(params);
showZyp(name);
});
} 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; // 分公司的名称
console.log(params);
showZyp(name);
});
}
startNum += 20;
endNum += 20;
}, intervalTime);
// 为echarts对象加载数据
myChart.setOption(option);
myChart.on('click', function(params) {
var name = params.name; // 分公司的名称
console.log(params);
showZyp(name);
});
}
function loading() {
$(document).on('click', '#progWitnes', function(e) {
//关闭遮罩层的代码或者需要在点击指定区域之外区域才执行的代码
openSafetyCheck(); // 安全检查
});
$(document).on('click', '#leftPhotoBtn', function(e) {
e.stopPropagation(); //阻止冒泡
//需要执行的代码
});
$(document).on('click', '#rightPhotoBtn', function(e) {
e.stopPropagation(); //阻止冒泡
//需要执行的代码
});
}
function openSafetyCheck() {
localStorage.setItem("titleName", "安全检查");
var index = top.layer.open({
title: false,
type: 2,
content: '../../page/security/securityCount.html',
area: ['90%', '90%'],
maxmin: false
});
}