index.vue 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503
  1. <template>
  2. <!-- 首页 - littlegreen -->
  3. <div :class="className" :style="{ height: '100%', width: width }">
  4. <el-row
  5. :gutter="20"
  6. class="i-row"
  7. style="margin-left: 0px; margin-right: 0px"
  8. >
  9. <el-col>
  10. <el-card>
  11. <div class="i-gq">
  12. <h3 class="i-title">政府与企业总投入</h3>
  13. <el-dropdown>
  14. <span
  15. class="el-dropdown-link"
  16. style="color: black; font-size: 16px; font-weight: bold"
  17. >
  18. {{ selectYearName }}
  19. <i
  20. class="el-icon-arrow-down el-icon--right"
  21. style="font-size: 16px; font-weight: bold"
  22. ></i>
  23. <!-- <i class="el-icon-sort el-icon--right" style="font-size: 16px;font-weight: bold;transform:rotate(90deg)"></i> -->
  24. </span>
  25. <el-dropdown-menu slot="dropdown">
  26. <el-dropdown-item
  27. v-for="(data, i) in yearDataList"
  28. :key="i"
  29. @click.native="handleDrop(data)"
  30. >
  31. {{ data.name }}
  32. </el-dropdown-item>
  33. </el-dropdown-menu>
  34. </el-dropdown>
  35. </div>
  36. <el-row :gutter="20">
  37. <el-col :span="6">
  38. <div>
  39. <p class="i-name">土地/亩</p>
  40. <p class="i-number">
  41. {{ indexData.landArea ? indexData.landArea : "-" }}
  42. </p>
  43. </div>
  44. </el-col>
  45. <el-col :span="6"
  46. ><div>
  47. <p class="i-name">电力/万千瓦时</p>
  48. <p class="i-number">
  49. {{
  50. indexData.powerConsumeSum ? indexData.powerConsumeSum : "-"
  51. }}
  52. </p>
  53. </div></el-col
  54. >
  55. <el-col :span="6"
  56. ><div>
  57. <p class="i-name">天然气/立方米</p>
  58. <p class="i-number">
  59. {{
  60. indexData.energyConsumeSum
  61. ? indexData.energyConsumeSum
  62. : "-"
  63. }}
  64. </p>
  65. </div></el-col
  66. >
  67. <el-col :span="6">
  68. <div>
  69. <p class="i-name">研发经费/万元</p>
  70. <p class="i-number">
  71. {{ indexData.fundingSum ? indexData.fundingSum : "-" }}
  72. </p>
  73. </div>
  74. </el-col>
  75. </el-row>
  76. </el-card>
  77. </el-col>
  78. </el-row>
  79. <el-row
  80. :gutter="20"
  81. class="i-row"
  82. style="margin-left: 0px; margin-right: 0px"
  83. >
  84. <el-col :span="14">
  85. <el-card>
  86. <h3 class="i-title">行业分类企业数量</h3>
  87. <el-row>
  88. <el-col :span="24">
  89. <div
  90. ref="piechart"
  91. :style="{ height: height, width: width }"
  92. ></div>
  93. </el-col>
  94. </el-row>
  95. </el-card>
  96. </el-col>
  97. <el-col :span="10" style="height: 100%">
  98. <el-card>
  99. <h3 class="i-title">产出总效益</h3>
  100. <el-row
  101. :style="{ height: height, width: width }"
  102. style="
  103. display: flex;
  104. flex-direction: column;
  105. justify-content: space-between;
  106. "
  107. >
  108. <el-col :span="24"
  109. ><div class="i-out-box">
  110. <p class="i-name">工业总产值/万元</p>
  111. <p class="i-number">
  112. {{
  113. indexData.totalIndustrialValueSum
  114. ? indexData.totalIndustrialValueSum
  115. : "-"
  116. }}
  117. </p>
  118. </div></el-col
  119. >
  120. <el-col :span="24"
  121. ><div class="i-out-box">
  122. <p class="i-name">应税收入/万元</p>
  123. <p class="i-number">
  124. {{
  125. indexData.taxableIncomeSum
  126. ? indexData.taxableIncomeSum
  127. : "-"
  128. }}
  129. </p>
  130. </div></el-col
  131. >
  132. <el-col :span="24"
  133. ><div class="i-out-box">
  134. <p class="i-name">实缴税金/万元</p>
  135. <p class="i-number">
  136. {{ indexData.paidTaxSum ? indexData.paidTaxSum : "-" }}
  137. </p>
  138. </div></el-col
  139. >
  140. </el-row>
  141. </el-card>
  142. </el-col>
  143. </el-row>
  144. <el-row
  145. class="i-row"
  146. :gutter="20"
  147. style="margin-left: 0px; margin-right: 0px"
  148. >
  149. <el-col :span="24">
  150. <el-card>
  151. <h3 class="i-title">行业分类企业数量</h3>
  152. <div ref="chart" :style="{ height: height, width: width }"></div>
  153. </el-card>
  154. </el-col>
  155. </el-row>
  156. </div>
  157. </template>
  158. <script>
  159. import * as echarts from "echarts";
  160. import resize from "./dashboard/mixins/resize";
  161. import { getBarData, getPieData, getIndexData } from "@/api/home";
  162. export default {
  163. mixins: [resize],
  164. props: {
  165. className: {
  166. type: String,
  167. default: "chart",
  168. },
  169. width: {
  170. type: String,
  171. default: "100%",
  172. },
  173. height: {
  174. type: String,
  175. default: "300px",
  176. },
  177. },
  178. data() {
  179. return {
  180. chart: null,
  181. chartData: [],
  182. piechart: null,
  183. pieChartData: [],
  184. yearDataList: [
  185. {
  186. name: "总和",
  187. key: 0,
  188. },
  189. ],
  190. selectYearName: "总和",
  191. selectYear: 0,
  192. indexData: {
  193. createBy: null,
  194. createTime: null,
  195. updateBy: null,
  196. updateTime: null,
  197. remark: null,
  198. id: null,
  199. year: null,
  200. landArea: null,
  201. powerConsumeSum: null,
  202. energyConsumeSum: null,
  203. fundingSum: null,
  204. employeeNumberSum: null,
  205. profitSum: null,
  206. enterpriseNumbers: null,
  207. totalIndustrialValueSum: null,
  208. taxableIncomeSum: null,
  209. paidTaxSum: null,
  210. },
  211. };
  212. },
  213. mounted() {
  214. this.fetchData();
  215. // this.initChart();
  216. // this.initPieChart();
  217. },
  218. beforeDestroy() {
  219. if (this.chart) {
  220. this.chart.dispose();
  221. }
  222. if (this.piechart) {
  223. this.piechart.dispose();
  224. }
  225. },
  226. methods: {
  227. // 初始化柱状图
  228. initChart() {
  229. if (this.chart) {
  230. this.chart.dispose();
  231. }
  232. this.chart = echarts.init(this.$refs.chart);
  233. console.log(this.chartData);
  234. // 饼图
  235. this.chart.setOption(
  236. {
  237. tooltip: {
  238. trigger: "axis",
  239. axisPointer: {
  240. type: "shadow",
  241. },
  242. },
  243. dataZoom: [
  244. {
  245. type: "slider",
  246. yAxisIndex: 0,
  247. left: 0,
  248. start: 95,
  249. end: 100,
  250. },
  251. {
  252. type: "inside",
  253. yAxisIndex: 0,
  254. },
  255. ],
  256. legend: {},
  257. grid: {
  258. top: "2%",
  259. left: "4%",
  260. right: "2%",
  261. bottom: "2%",
  262. containLabel: true,
  263. },
  264. xAxis: {
  265. type: "value",
  266. boundaryGap: [0, 0.01],
  267. },
  268. yAxis: {
  269. type: "category",
  270. // inverse: true,
  271. data: this.chartData.map((item) => item.industryName),
  272. },
  273. series: [
  274. {
  275. // realtimeSort: true,
  276. type: "bar",
  277. data: this.chartData.map((item) => item.number),
  278. label: {
  279. show: true,
  280. formatter: "{c}",
  281. position: "right",
  282. },
  283. barWidth: "30%",
  284. itemStyle: {
  285. color: new echarts.graphic.LinearGradient(0.8, 0, 0, 0, [
  286. { offset: 0, color: "#83bff6" },
  287. { offset: 0.5, color: "#188df0" },
  288. { offset: 1, color: "#188df0" },
  289. ]),
  290. barBorderRadius: [0, 50, 50, 0],
  291. },
  292. },
  293. ],
  294. }
  295. // {
  296. // title: {
  297. // text: 'Referer of a Website',
  298. // subtext: 'Fake Data',
  299. // left: 'center'
  300. // },
  301. // tooltip: {
  302. // trigger: "item",
  303. // },
  304. // legend: {
  305. // type: "scroll",
  306. // scrollDataIndex: 0,
  307. // orient: "vertical",
  308. // left: 10,
  309. // itemGap: 20,
  310. // top: "middle",
  311. // align: "left",
  312. // icon: "circle",
  313. // formatter: (name) => {
  314. // if (!name) return "";
  315. // return this.getEqualNewlineString(name, 10); // 根据你的需求修改参数
  316. // },
  317. // },
  318. // series: [
  319. // {
  320. // radius: ['20%', '100%'],
  321. // center: ['65%', '50%'],
  322. // avoidLabelOverlap: false,
  323. // type: "pie",
  324. // radius: "50%",
  325. // data: [
  326. // { value: 1048, name: "文教、工美、体育和娱乐用品制造业" },
  327. // { value: 735, name: "皮革、毛皮、羽毛及其制品和制鞋业" },
  328. // { value: 580, name: "电气机械和器材制造业" },
  329. // { value: 484, name: "印刷和记录媒介复制业" },
  330. // { value: 300, name: "电气机械和器材制造业" },
  331. // { value: 300, name: "皮革、毛皮、羽毛及其制品和制鞋业" },
  332. // { value: 300, name: "金属制品业" },
  333. // { value: 300, name: "农副食品加工业" },
  334. // { value: 300, name: "酒、饮料和精制茶制造业" },
  335. // { value: 300, name: "造纸和纸制品业" },
  336. // ],
  337. // itemStyle: {
  338. // normal: {
  339. // label: {
  340. // show: false,
  341. // },
  342. // labelLine: {
  343. // show: false,
  344. // },
  345. // },
  346. // },
  347. // },
  348. // ],
  349. // }
  350. );
  351. },
  352. //params 要处理的字符串
  353. //length 每行显示长度
  354. getEqualNewlineString(params, length) {
  355. let text = "";
  356. let count = Math.ceil(params.length / length); // 向上取整数
  357. // 一行展示length个
  358. if (count > 1) {
  359. for (let z = 1; z <= count; z++) {
  360. text += params.substr((z - 1) * length, length);
  361. if (z < count) {
  362. text += "\n";
  363. }
  364. }
  365. } else {
  366. text += params.substr(0, length);
  367. }
  368. return text;
  369. },
  370. // 初始化饼图
  371. initPieChart() {
  372. if (this.piechart) {
  373. this.piechart.dispose();
  374. }
  375. // console.log(this.pieChartData);
  376. let chartArray = this.pieChartData.map((item) => {
  377. return {
  378. value: item.number,
  379. name: item.industryName,
  380. };
  381. });
  382. this.piechart = echarts.init(this.$refs.piechart);
  383. this.piechart.setOption({
  384. tooltip: {
  385. trigger: "item",
  386. },
  387. series: [
  388. {
  389. type: "pie",
  390. radius: ["40%", "75%"],
  391. center: ["50%", "50%"],
  392. avoidLabelOverlap: false,
  393. itemStyle: {
  394. borderRadius: 5,
  395. borderColor: "#fff",
  396. borderWidth: 2,
  397. },
  398. label: {
  399. show: true,
  400. },
  401. labelLine: {
  402. show: true,
  403. },
  404. data: chartArray,
  405. },
  406. ],
  407. });
  408. },
  409. // 切换年份
  410. handleDrop(e) {
  411. this.selectYear = e?.key;
  412. this.selectYearName = e?.name;
  413. this.updateData(this.selectYear);
  414. },
  415. fetchData() {
  416. getBarData()
  417. .then((res) => {
  418. if (res && res?.rows) {
  419. this.chartData = res.rows;
  420. this.initChart();
  421. }
  422. })
  423. .catch((error) => {
  424. console.error("Error fetching data:", error);
  425. });
  426. getPieData()
  427. .then((res) => {
  428. if (res && res?.rows) {
  429. this.pieChartData = res.rows;
  430. this.initPieChart();
  431. }
  432. })
  433. .catch((error) => {
  434. console.error("Error fetching data:", error);
  435. });
  436. this.updateData(this.selectYear);
  437. },
  438. updateData(year) {
  439. const that = this;
  440. getIndexData({
  441. year: year,
  442. })
  443. .then((res) => {
  444. that.indexData = res?.rows[0];
  445. let arr = res?.rows[0].years.map((item) => {
  446. return {
  447. name: item,
  448. key: item,
  449. };
  450. });
  451. that.yearDataList = [
  452. {
  453. name: "总和",
  454. key: 0,
  455. },
  456. ...arr,
  457. ];
  458. })
  459. .catch((error) => {
  460. console.error("Error fetching data:", error);
  461. });
  462. },
  463. },
  464. };
  465. </script>
  466. <style lang="scss" scoped>
  467. .i-gq {
  468. display: flex;
  469. justify-content: space-between;
  470. align-items: center;
  471. }
  472. .i-row {
  473. margin: 15px 0;
  474. .i-title {
  475. font-weight: bold;
  476. margin: 10px 0 25px;
  477. }
  478. p {
  479. margin: 0;
  480. }
  481. .i-number {
  482. font-size: 40px;
  483. font-weight: bold;
  484. letter-spacing: 2px;
  485. }
  486. .i-name {
  487. letter-spacing: 1px;
  488. margin-bottom: 10px;
  489. }
  490. .i-out-box {
  491. display: flex;
  492. justify-content: space-between;
  493. align-items: center;
  494. margin: 10px 0;
  495. .i-name {
  496. margin-bottom: 0;
  497. }
  498. }
  499. }
  500. </style>