老产品前端代码
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

731 lines
21 KiB

4 years ago
<template>
<div class="warning-box">
4 years ago
<!-- 组织路由 -->
<div class="div_top">
<div class="router_line"></div>
<div class="div_router">
<span class="router_parents"
v-for="(item,index) in runAgencyArray"
@click="handleClickAgency(index)"
:key="index">{{item.orgName}}<span class="arrow">></span></span>
<span class="router_child">{{orgName}}</span>
</div>
</div>
3 years ago
<cpt-card v-if="!showHouseList&&!showPeopleList"
:min-full-screen="true">
4 years ago
<div class="card-title">
<img class="title-icon"
src="@/assets/img/shuju/title-tip.png" />
<div class="title-label">
4 years ago
人房概览数据统计
4 years ago
4 years ago
</div>
</div>
4 years ago
<div class="card-left-title">本级人房概览数据统计</div>
4 years ago
<div class="card-echart">
4 years ago
4 years ago
<div class="card-left">
4 years ago
<div v-if="!dataLoading"
class="div-chart">
<screen-echarts-frame class="echart-wr"
@myChartMethod="housePieInitOk"
ref="housePieChart"></screen-echarts-frame>
<div class="div-tip">
<div :class="['legend_item',{'item_last':index===legendArray.length-1}]"
v-for="(item,index) in legendArray"
:key="index">
<div class="item_name">{{item.name}}</div>
<img :src="item.url" />
4 years ago
</div>
</div>
</div>
4 years ago
<div v-if="!dataLoading"
class="pie-table">
3 years ago
<div class="pie-table-total"
@click="handleClickHouse('')">
4 years ago
<div class="pie-table-total-count">{{houseData.houseTotal}}</div>
<div class="pie-table-title">房屋总数</div>
</div>
<div class="pie-table-line"></div>
3 years ago
<div class="pie-table-total "
@click="handleClickHouse('0')">
4 years ago
<div class="pie-table-total-count zz">{{houseData.zzHouseTotal}}</div>
<div class="pie-table-title">自住房屋数</div>
</div>
3 years ago
<div class="pie-table-total "
@click="handleClickHouse('1')">
4 years ago
<div class="pie-table-total-count cz">{{houseData.czHouseTotal}}</div>
<div class="pie-table-title">出租房屋数</div>
4 years ago
</div>
3 years ago
<div class="pie-table-total "
@click="handleClickHouse('2')">
4 years ago
<div class="pie-table-total-count xz">{{houseData.xzHouseTotal}}</div>
<div class="pie-table-title">闲置房屋数</div>
</div>
3 years ago
<div class="pie-table-total "
@click="handleClickHouse('3')">
3 years ago
<div class="pie-table-total-count wsc">{{houseData.wscHouseTotal}}</div>
3 years ago
<div class="pie-table-title">未出售房屋数</div>
</div>
4 years ago
</div>
<div class="loading-status"
v-if="dataLoading">
<screen-loading>加载中</screen-loading>
4 years ago
</div>
4 years ago
4 years ago
</div>
4 years ago
4 years ago
<div class="card-left">
4 years ago
<div v-if="!dataLoading"
class="div-chart">
<screen-echarts-frame class="echart-wr"
@myChartMethod="userPieInitOk"
ref="userPieChart"></screen-echarts-frame>
<div class="div-tip2">
<div class="cz-tip">
<div class="cz-tip-dot"></div>
<span>常住人口数</span>
</div>
<div class="ld-tip">
<div class="ld-tip-dot"></div>
<span>流动人口数</span>
</div>
4 years ago
</div>
4 years ago
</div>
<div v-if="!dataLoading"
class="pie-table">
3 years ago
<div class="pie-table-total"
@click="handleClickPeople('all')">
4 years ago
<div class="pie-table-total-count">{{userData.userTotal}}</div>
<div class="pie-table-title">居民总数</div>
</div>
<div class="pie-table-line"></div>
3 years ago
<div class="pie-table-total "
@click="handleClickPeople('cz')">
4 years ago
<div class="pie-table-total-count zz">{{userData.czUserTotal}}</div>
<div class="pie-table-title">常住人口数</div>
4 years ago
</div>
3 years ago
<div class="pie-table-total "
@click="handleClickPeople('ld')">
4 years ago
<div class="pie-table-total-count cz">{{userData.ldUserTotal}}</div>
<div class="pie-table-title">流动人口数</div>
</div>
4 years ago
</div>
4 years ago
<div class="loading-status"
v-if="dataLoading">
<screen-loading>加载中</screen-loading>
4 years ago
</div>
4 years ago
</div>
</div>
4 years ago
<div v-if="orgType!=='village'">
<div class="card-left-title">下级人房概览数据统计</div>
<div v-if="subList.length>0"
class="card-table">
<div v-for="(item,index) in subList"
:key="index"
:class="['table_item',index%2 === 0?'item_dark':'']">
<div class="item_name"
@click="handleToSubAgency(item)">
<img src="@/assets/img/shuju/logo1.png" />
<span>{{item.orgName}}</span>
4 years ago
</div>
4 years ago
<div class="item_data">
<div class="item_left">
<div class="pie-table-total">
<div class="pie-table-total-count">{{item.houseTotal}}</div>
<div class="pie-table-title">房屋总数</div>
</div>
<div class="pie-table-line"></div>
<div class="pie-table-total ">
<div class="pie-table-total-count colorwhite">{{item.zzHouseTotal}}</div>
<div class="pie-table-title table-table-title">{{item.zzHouseRatio+'%'}}</div>
<div class="pie-table-title table-table-title">自住房屋数</div>
</div>
<div class="pie-table-total ">
<div class="pie-table-total-count colorwhite">{{item.czHouseTotal}}</div>
<div class="pie-table-title table-table-title">{{item.czHouseRatio+'%'}}</div>
<div class="pie-table-title table-table-title">出租房屋数</div>
</div>
<div class="pie-table-total ">
<div class="pie-table-total-count colorwhite">{{item.xzHouseTotal}}</div>
<div class="pie-table-title table-table-title">{{item.xzHouseRatio+'%'}}</div>
<div class="pie-table-title table-table-title">闲置房屋数</div>
</div>
3 years ago
<div class="pie-table-total ">
<div class="pie-table-total-count colorwhite">{{item.wscHouseTotal}}</div>
<div class="pie-table-title table-table-title">{{item.wscHouseRatio+'%'}}</div>
<div class="pie-table-title table-table-title">未出售房屋数</div>
</div>
4 years ago
</div>
4 years ago
<div class="item_right">
<div class="pie-table-total">
<div class="pie-table-total-count">{{item.userTotal}}</div>
<div class="pie-table-title">居民总数</div>
</div>
<div class="pie-table-line"></div>
<div class="pie-table-total ">
<div class="pie-table-total-count colorwhite">{{item.czUserTotal}}</div>
<div class="pie-table-title table-table-title">{{item.czUserRatio+'%'}}</div>
<div class="pie-table-title table-table-title">常住人口数</div>
</div>
<div class="pie-table-total ">
<div class="pie-table-total-count colorwhite">{{item.ldUserTotal}}</div>
<div class="pie-table-title table-table-title">{{item.ldUserRatio+'%'}}</div>
<div class="pie-table-title table-table-title">流动人口数</div>
</div>
4 years ago
4 years ago
</div>
4 years ago
</div>
</div>
</div>
4 years ago
<div v-if="subList.length===0"
class="no-data">
<img src="@/assets/img/modules/visual/noData.png"
class="no-data-img" />
4 years ago
4 years ago
</div>
4 years ago
</div>
4 years ago
</cpt-card>
3 years ago
<house-list v-if="showHouseList "
:orgId="orgId"
:orgType="orgType"
:rentType="rentType"
@close="showHouseList = false">
</house-list>
<people-list v-if="showPeopleList "
:orgId="orgId"
:orgType="orgType"
:type="type"
@close="showPeopleList = false">
</people-list>
4 years ago
</div>
</template>
<script>
import { requestPost } from "@/js/dai/request";
import screenTable from "../../components/screen-table/index";
import cptCard from "@/views/modules/visual/cpts/card";
import nextTick from "dai-js/tools/nextTick";
import screenEchartsFrame from "../../components/screen-echarts-frame";
4 years ago
import ScreenLoading from "@/views/modules/visual/components/screen-loading";
import { housePieOption } from './options'
import { userPieOption } from './userOptions'
3 years ago
import houseList from './houseList'
import peopleList from './peopleList'
4 years ago
import * as echarts from 'echarts';
export default {
name: "warning-box",
components: {
cptCard,
screenTable,
4 years ago
screenEchartsFrame,
3 years ago
ScreenLoading,
houseList,
peopleList
4 years ago
},
data () {
return {
4 years ago
dataLoading: true,
orgId: '',
orgType: '',
4 years ago
orgName: this.$store.state.user.agencyName,
// orgShowName: this.$store.state.user.agencyName,//面包屑显示当前组织名称
4 years ago
housePieChartS: null,
housePieChart: '',
housePieOption: {},
housePieInitState: false,
houseData: {
orgId: '',//组织、网格、小区Id
orgType: '',//组织、网格、小区类型 agency grid village
houseTotal: 198000,//房屋总数
zzHouseTotal: 2000,//房屋自住总数
zzHouseRatio: '90%',//房屋自住总数占比(保留两位小数,带百分号的)
czHouseTotal: 30,//房屋出租总数
czHouseRatio: '5%',//房屋出租总数占比(保留两位小数,带百分号的)
xzHouseTotal: 200,//房屋闲置总数
xzHouseRatio: '70%',//房屋闲置总数占比(保留两位小数,带百分号的)
3 years ago
wscHouseTotal: 100,//房屋未售出总数
wscHouseRatio: '20%',//房屋未售出总数占比
4 years ago
},
3 years ago
houseColorArray: ['#3dda83', '#e43c26', '#fac126', '#fc8452'],
4 years ago
housePieData: [],
legendArray: [
4 years ago
{
4 years ago
name: '自住房屋数',
url: require('../../../../../assets/img/shuju/measure/lv@2x.png')
4 years ago
},
{
4 years ago
name: '出租房屋数',
url: require('../../../../../assets/img/shuju/measure/hong@2x.png')
4 years ago
},
{
4 years ago
name: '闲置房屋数',
url: require('../../../../../assets/img/shuju/measure/huang@2x.png')
3 years ago
},
{
name: '未出售房屋数',
url: require('../../../../../assets/img/shuju/measure/cheng.png')
4 years ago
}
],
4 years ago
userPieChartS: null,
userPieChart: '',
userPieOption: {},
userPieInitState: false,
userData: {
orgId: '',//组织、网格、小区Id
orgType: '',//组织、网格、小区类型 agency grid village
userTotal: 198000,//居民总数
czUserTotal: 2000,//常住居民总数
czUserRatio: '90%',//常住居民总数占比
ldUserTotal: 30,//流动居民总数
ldUserRatio: '5%',//流动居民总数占比
},
userColorArray: ['#3dda83', '#e43c26'],
4 years ago
userPieData: [],
4 years ago
subList: [],
//下钻层级记录
runNum: 0,
runAgencyArray: [],
selUserId: '',
center: [],
zoom: null,
parentPolygon: [],
4 years ago
3 years ago
rentType: '',//点击房屋数类型
type: '',//点击人员数类型
showPeopleList: false,
showHouseList: false
4 years ago
};
},
async mounted () {
4 years ago
4 years ago
await this.getApiData()
4 years ago
4 years ago
},
methods: {
4 years ago
async getApiData () {
4 years ago
this.dataLoading = true
4 years ago
4 years ago
this.housePieInitState = false
this.userPieInitState = false
4 years ago
await this.getHousechart()
await this.getUserchart()
await this.getSubuserhouselist()
this.dataLoading = false
await nextTick(500)
4 years ago
this.getHousePie()
this.getUserPie()
4 years ago
3 years ago
},
4 years ago
3 years ago
//点击房屋数
handleClickHouse (rentType) {
this.toSubAgency('house')
this.rentType = rentType
this.showHouseList = true
},
//点击人员数
handleClickPeople (type) {
this.toSubAgency('people')
this.type = type
this.showPeopleList = true
4 years ago
},
3 years ago
4 years ago
housePieInitOk (dom) {
4 years ago
console.log('pie准备好了', dom)
4 years ago
this.housePieChartS = dom
4 years ago
// this.housePieInitState = true
4 years ago
},
4 years ago
userPieInitOk (dom) {
console.log('pie准备好了', dom)
this.userPieChartS = dom
4 years ago
// this.userPieInitState = true
4 years ago
},
4 years ago
async getHousechart (node, resolve) {
if (this.$refs.housePieChart) {
this.$refs.housePieChart.showLoading()
4 years ago
}
4 years ago
// const url = "http://yapi.elinkservice.cn/mock/245/gov/org/house/housechart";
const url = '/gov/org/house/housechart'
4 years ago
let params = {
orgId: this.orgId,
orgType: this.orgType
};
const { data, code, msg } = await requestPost(url, params);
if (code === 0) {
4 years ago
this.houseData = data
4 years ago
if (this.$refs.housePieChart) {
this.$refs.housePieChart.hideLoading()
}
3 years ago
this.orgId = data.orgId
this.orgType = data.orgType
4 years ago
} else {
this.houseData = {}
this.$message.error(msg);
}
4 years ago
this.housePieInitState = true
4 years ago
},
4 years ago
getHousePie () {
if (this.housePieInitState) {
this.assignHousePieChart()
} else {
setTimeout(() => {
this.getHousePie()
}, 500)
4 years ago
}
4 years ago
},
4 years ago
4 years ago
assignHousePieChart () {
if (this.houseData) {
this.$refs.housePieChart.setNoData(false)
this.$refs.housePieChart.clear()
this.housePieData = []
const _that = this
// 获取pieChart配置
this.housePieOption = housePieOption(this.housePieChartS)
// let maxValue = this.housePieData[0].total
// let maxIndex = 0
let obj1 = {
name: '自住房屋数',
4 years ago
value: this.houseData.zzHouseRatio,
4 years ago
selected: true
}
let obj2 = {
name: '出租房屋数',
4 years ago
value: this.houseData.czHouseRatio
4 years ago
}
let obj3 = {
name: '闲置房屋数',
4 years ago
value: this.houseData.xzHouseRatio
4 years ago
}
3 years ago
let obj4 = {
name: '未出售房屋数',
value: this.houseData.wscHouseRatio
}
4 years ago
this.housePieData.push(obj1)
this.housePieData.push(obj2)
this.housePieData.push(obj3)
3 years ago
this.housePieData.push(obj4)
4 years ago
this.housePieOption.title.text = this.houseData.houseTotal
this.housePieOption.series[1].itemStyle = {
color: function (params) {
return _that.houseColorArray[params.dataIndex]
4 years ago
}
}
4 years ago
let fun = function (params) {
_that.clickHousePie(params.dataIndex)
}
this.$refs.housePieChart.handleClick(fun)
this.clickHousePie(0)
} else {
this.$refs.housePieChart.setNoData(true)
4 years ago
}
4 years ago
},
async getUserchart (node, resolve) {
if (this.$refs.userPieChart) {
this.$refs.userPieChart.showLoading()
}
4 years ago
// const url = "http://yapi.elinkservice.cn/mock/245/epmetuser/icresiuser/userchart";
const url = '/epmetuser/icresiuser/userchart'
4 years ago
let params = {
orgId: this.orgId,
orgType: this.orgType
};
const { data, code, msg } = await requestPost(url, params);
if (code === 0) {
4 years ago
this.userData = data
4 years ago
if (this.$refs.userPieChart) {
this.$refs.userPieChart.hideLoading()
}
} else {
this.userData = {}
this.$message.error(msg);
4 years ago
}
4 years ago
this.userPieInitState = true
4 years ago
},
4 years ago
4 years ago
getUserPie () {
if (this.userPieInitState) {
this.assignUserPieChart()
} else {
setTimeout(() => {
this.getUserPie()
}, 500)
}
4 years ago
},
4 years ago
4 years ago
assignUserPieChart () {
if (this.userData) {
this.$refs.userPieChart.setNoData(false)
this.$refs.userPieChart.clear()
this.userPieData = []
const _that = this
// 获取pieChart配置
this.userPieOption = userPieOption(this.userPieChartS)
// let maxValue = this.userPieData[0].total
// let maxIndex = 0
let obj1 = {
name: '常住人口数',
4 years ago
value: this.userData.czUserRatio,
4 years ago
selected: true
}
let obj2 = {
4 years ago
name: '流动人口数',
4 years ago
value: this.userData.ldUserRatio
4 years ago
}
4 years ago
4 years ago
this.userPieData.push(obj1)
this.userPieData.push(obj2)
this.userPieOption.title.text = this.userData.userTotal
this.userPieOption.series[1].itemStyle = {
color: function (params) {
return _that.userColorArray[params.dataIndex]
4 years ago
}
4 years ago
}
4 years ago
4 years ago
let fun = function (params) {
_that.clickUserPie(params.dataIndex)
}
this.$refs.userPieChart.handleClick(fun)
this.clickUserPie(0)
} else {
this.$refs.userPieChart.setNoData(true)
}
4 years ago
},
4 years ago
async getSubuserhouselist (node, resolve) {
4 years ago
// const url = "http://yapi.elinkservice.cn/mock/245/gov/org/house/subuserhouselist";
const url = '/gov/org/house/subuserhouselist'
4 years ago
let params = {
orgId: this.orgId,
orgType: this.orgType
};
const { data, code, msg } = await requestPost(url, params);
if (code === 0) {
this.subList = data
4 years ago
4 years ago
} else {
}
},
async clickHousePie (seriesIndex) {
this.housePieData.forEach((element, index) => {
if (index === seriesIndex) {
4 years ago
element.label = {
show: true,
};
element.labelLine = {
show: true,
lineStyle: {
opacity: 1,
}
};
4 years ago
console.log('zhilma')
4 years ago
} else {
element.label = {
show: false,
};
element.labelLine = {
show: false,
lineStyle: {
opacity: 0,
color: 'rgba(255,255,255,0)'
}
};
}
});
4 years ago
this.housePieOption.series[1].data = this.housePieData
// this.$refs.housePieChart.hideLoading()
this.$refs.housePieChart.setOption(this.housePieOption)
4 years ago
},
4 years ago
4 years ago
async clickUserPie (seriesIndex) {
this.userPieData.forEach((element, index) => {
4 years ago
if (index === seriesIndex) {
element.label = {
show: true,
};
element.labelLine = {
show: true,
lineStyle: {
opacity: 1,
}
};
4 years ago
console.log('zhilma')
4 years ago
} else {
element.label = {
show: false,
};
element.labelLine = {
show: false,
lineStyle: {
opacity: 0,
color: 'rgba(255,255,255,0)'
}
};
}
});
4 years ago
this.userPieOption.series[1].data = this.userPieData
// this.$refs.userPieChart.hideLoading()
this.$refs.userPieChart.setOption(this.userPieOption)
4 years ago
4 years ago
// this.getTable()
4 years ago
},
4 years ago
async handleToSubAgency (item) {
if (!this.dataLoading) {
3 years ago
this.toSubAgency('subAgency', item)
4 years ago
await this.getApiData()
}
4 years ago
},
4 years ago
//下钻到下一级
3 years ago
async toSubAgency (type, item) {
4 years ago
this.runNum++
let obj = {
orgId: this.orgId,
orgType: this.orgType,
orgName: this.orgName,
3 years ago
type: type
4 years ago
}
3 years ago
this.runAgencyArray.push(obj)
4 years ago
3 years ago
if (type === 'subAgency') {
4 years ago
3 years ago
this.orgId = item.orgId
this.orgType = item.orgType
this.orgName = item.orgName
4 years ago
3 years ago
} else if (type === 'house') {
4 years ago
3 years ago
this.orgName = '房屋列表'
} else if (type === 'people') {
this.orgName = '人员列表'
}
4 years ago
},
//返回所选组织
handleClickAgency (index) {
3 years ago
4 years ago
const cutNum = this.runAgencyArray.length - index//要减去的长度
this.runNum = this.runNum - cutNum
4 years ago
4 years ago
let orgData = this.runAgencyArray[index]
4 years ago
console.log('----------------', orgData)
4 years ago
for (let i = 0; i < cutNum; i++) {
this.runAgencyArray.pop()
}
4 years ago
this.orgId = orgData.orgId
4 years ago
this.orgType = orgData.orgType
this.orgName = orgData.orgName
3 years ago
this.showHouseList = false
this.showPeopleList = false
// if (orgData.type === 'house') {
// this.showHouseList = false
// }
// if (orgData.type === 'people') {
// this.showPeopleList = false
// }
4 years ago
this.getApiData()
4 years ago
4 years ago
},
4 years ago
},
};
</script>
<style
lang="scss"
src="@/assets/scss/modules/visual/warning.scss"
scoped
></style>
4 years ago
<style
lang="scss"
src="@/assets/scss/modules/visual/basicInfoMain.scss"
scoped
></style>
4 years ago
<style
lang="scss"
src="@/assets/scss/modules/visual/houseStatic.scss"
scoped
></style>