gatewaynNewPage.vue 62 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442
  1. <template>
  2. <div class="gatewayNewPage">
  3. <el-row>
  4. <el-col :span="18" class="quarter">
  5. <div class="searchFn">
  6. <div class="searchFn_left">
  7. <el-date-picker v-model="changeNewYear" type="year" value-format="YYYY" placeholder="选择年份"
  8. @change="changeNewYearFn" :style="getPickerSty()" />
  9. </div>
  10. <div class="searchFn_right">
  11. <el-date-picker v-model="changeYear" type="year" value-format="YYYY" placeholder="选择年份"
  12. @change="changeYearFn" :style="getPickerSty()" />
  13. <div class="quarterChoose">
  14. <el-icon :size="20" color="#3B7AD1" @click="arrowLeft">
  15. <ArrowLeft />
  16. </el-icon>
  17. <span class="choose">{{seasonStr}}</span>
  18. <el-icon :size="20" color="#3B7AD1" @click="arrowRight">
  19. <ArrowRight />
  20. </el-icon>
  21. </div>
  22. </div>
  23. </div>
  24. <div class="tableHeader">
  25. <div class="headerOne"></div>
  26. <div class="headerTwo">
  27. <div class="headerComTit">
  28. <span class="headerTwoTit">评级统计</span>
  29. </div>
  30. </div>
  31. <div class="headerThree">
  32. <div class="headerComTit">
  33. <span class="headerThreeTit">年度榜</span>
  34. </div>
  35. <div class="headerNameTit">
  36. <div class="headerNameTit_left">
  37. <span>单位名称</span>
  38. </div>
  39. <div class="headerNameTit_right">
  40. <span>级别</span>
  41. <span style="margin-left: 20px">得分</span>
  42. </div>
  43. </div>
  44. </div>
  45. <div class="headerFour">
  46. <div class="headerComTit">
  47. <span class="headerFourTit">考评排行榜</span>
  48. </div>
  49. <div class="headerNameForeTit">
  50. <div class="headerNameForeTit_left">
  51. <span>单位名称</span>
  52. </div>
  53. <div class="headerNameForeTit_right">
  54. <span>得分</span>
  55. <span>加分事项</span>
  56. <span>扣分事项</span>
  57. <span>管理加分</span>
  58. <span>管理扣分</span>
  59. <span>高于基准</span>
  60. <span>低于基准</span>
  61. </div>
  62. </div>
  63. </div>
  64. </div>
  65. <!-- v-for="it in 4" :key="it" -->
  66. <div class="tableMain" v-for="(it, index) in cupDataYearArr.section" :key="index">
  67. <div class="mainOne">
  68. <span :style="getMainOneSty()">{{it.name}}</span>
  69. </div>
  70. <div class="mainTwo">
  71. <!-- <div class="echartsNum" :style="it.echartsData.allNum < 10 ? 'left:70px': ''">
  72. {{it.echartsData.allNum}}</div> -->
  73. <div :id="'pieChart'+index" style="height: 100px;width: 100%"></div>
  74. <el-row class="mainTwoMsg" :style="getPos()">
  75. <el-col :span="12">
  76. <span class="mainTwoComColor" style="background: #F65177;"></span>
  77. <span class="mainTwoComTit">A级</span>
  78. </el-col>
  79. <el-col :span="12">
  80. <span class="mainTwoComColor" style="background: #50C14E;"></span>
  81. <span class="mainTwoComTit">B级</span>
  82. </el-col>
  83. <el-col :span="12">
  84. <span class="mainTwoComColor" style="background: #5093E1;"></span>
  85. <span class="mainTwoComTit">C级</span>
  86. </el-col>
  87. <el-col :span="12">
  88. <span class="mainTwoComColor" style="background: #9DA5BE;"></span>
  89. <span class="mainTwoComTit">D级</span>
  90. </el-col>
  91. </el-row>
  92. </div>
  93. <div class="mainThree">
  94. <div class="mainMore" @click="yearSeeMore(it.nameEn, 'year')"></div>
  95. <div style="display: flex" v-for="(item, index) in it.tableDatas" :key="index">
  96. <div class="mainThreeMsg">
  97. <img :src="item.img" alt="">
  98. <div class="msgProgress">
  99. <span
  100. :style="winPix === 1.25 || innerWidth < 1800?'font-size: 12px;width: 65%':''">{{item.company}}</span>
  101. <span>{{item.grade}}</span>
  102. <span :style="winPix === 1.25 || innerWidth < 1800?'width: 25%':''">{{item.score.toFixed(2)}}</span>
  103. </div>
  104. </div>
  105. </div>
  106. </div>
  107. <div class="mainFour">
  108. <div class="mainMore" @click="yearSeeMore(it.nameEn, 'season')"></div>
  109. <div style="display: flex" v-for="(item, index) in it.section" :key="index">
  110. <div class="mainFourMsg">
  111. <span class="mainFourcompany" :style="getFooter12Sty()">{{item.company}}</span>
  112. <div class="mainFourImg">
  113. <span class="mainFourImgSpan" :style="getFooterseaSty()">{{item.score.toFixed(2)}}</span>
  114. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  115. :width="200" trigger="hover" :content="item.matter_heigh_note">
  116. <template #reference>
  117. <img :src="item.matter_heigh === 0 ? cenImg : item.matter_heigh === 1 ? topImg : botImg"
  118. alt="">
  119. </template>
  120. </el-popover>
  121. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  122. :width="200" trigger="hover" :content="item.matter_low_note">
  123. <template #reference>
  124. <img :src="item.matter_low === 0 ? cenImg : item.matter_low === 1 ? topImg : botImg"
  125. alt="">
  126. </template>
  127. </el-popover>
  128. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  129. :width="200" trigger="hover" :content="item.manage_heigh_note">
  130. <template #reference>
  131. <img :src="item.manage_heigh === 0 ? cenImg : item.manage_heigh === 1 ? topImg : botImg"
  132. alt="">
  133. </template>
  134. </el-popover>
  135. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  136. :width="200" trigger="hover" :content="item.manage_low_note">
  137. <template #reference>
  138. <img :src="item.manage_low === 0 ? cenImg : item.manage_low === 1 ? topImg : botImg"
  139. alt="">
  140. </template>
  141. </el-popover>
  142. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  143. :width="200" trigger="hover" :content="item.standard_heigh_note">
  144. <template #reference>
  145. <img :src="item.standard_heigh === 0 ? cenImg : item.standard_heigh === 1 ? topImg : botImg"
  146. alt="">
  147. </template>
  148. </el-popover>
  149. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  150. :width="200" trigger="hover" :content="item.standard_low_note">
  151. <template #reference>
  152. <img :src="item.standard_low === 0 ? cenImg : item.standard_low === 1 ? topImg : botImg"
  153. alt="">
  154. </template>
  155. </el-popover>
  156. </div>
  157. </div>
  158. </div>
  159. </div>
  160. </div>
  161. <div class="tableFooter">
  162. <div class="footerOne">
  163. <span :style="getFooterOneSty()">煤电一体化</span>
  164. </div>
  165. <div class="footerTwo">
  166. <div style="display: flex" v-for="(item, index) in cupDataYearArr.integration" :key="index">
  167. <div class="footerTwoMsg">
  168. <img :src="item.img" alt="">
  169. <div class="footerProgress">
  170. <span class="footerOneSpan" :style="getFooter12Sty()">{{item.company}}</span>
  171. <el-progress :percentage="Math.floor((item.score/item.base_score)*100)"
  172. :stroke-width="5" />
  173. <span class="footerTwoSpan">{{item.grade}}</span>
  174. <span class="footerThreeSpan">{{item.score}}</span>
  175. </div>
  176. </div>
  177. </div>
  178. </div>
  179. <div class="footerThree">
  180. <div class="mainMore" @click="yearSeeMore('MDYTH', 'season')"></div>
  181. <!-- <div style="display: flex; justify-content: space-between;width: 100%"
  182. v-for="(item, index) in cupDataSeasonArr.integration" :key="index">
  183. <div class="footerThreeMsg" v-for="it in matterMsg" :key="it">
  184. <div class="footerImg">
  185. <span :style="getfooterSpan()">{{it}}</span>
  186. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  187. :width="200" trigger="hover" :content="item.matter_heigh_note">
  188. <template #reference>
  189. <img :src="item.matter_heigh === 0 ? cenImg : item.matter_heigh === 1 ? topImg : botImg"
  190. v-if="it === '加分事项'">
  191. </template>
  192. </el-popover>
  193. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  194. :width="200" trigger="hover" :content="item.matter_low_note">
  195. <template #reference>
  196. <img :src="item.matter_low === 0 ? cenImg : item.matter_low === 1 ? topImg : botImg"
  197. v-if="it === '扣分事项'">
  198. </template>
  199. </el-popover>
  200. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  201. :width="200" trigger="hover" :content="item.manage_heigh_note">
  202. <template #reference>
  203. <img :src="item.manage_heigh === 0 ? cenImg : item.manage_heigh === 1 ? topImg : botImg"
  204. v-if="it === '管理加分'">
  205. </template>
  206. </el-popover>
  207. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  208. :width="200" trigger="hover" :content="item.manage_low_note">
  209. <template #reference>
  210. <img :src="item.manage_low === 0 ? cenImg : item.manage_low === 1 ? topImg : botImg"
  211. v-if="it === '管理扣分'">
  212. </template>
  213. </el-popover>
  214. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  215. :width="200" trigger="hover" :content="item.standard_heigh_note">
  216. <template #reference>
  217. <img :src="item.standard_heigh === 0 ? cenImg : item.standard_heigh === 1 ? topImg : botImg"
  218. v-if="it === '高于基准'">
  219. </template>
  220. </el-popover>
  221. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  222. :width="200" trigger="hover" :content="item.standard_low_note">
  223. <template #reference>
  224. <img :src="item.standard_low === 0 ? cenImg : item.standard_low === 1 ? topImg : botImg"
  225. v-if="it === '低于基准'">
  226. </template>
  227. </el-popover>
  228. </div>
  229. </div>
  230. </div> -->
  231. <div style="display: flex" v-for="(item, index) in cupDataSeasonArr.integration" :key="index">
  232. <div class="mainFourMsg">
  233. <span class="mainFourcompany" :style="getFooter12Sty()">{{item.company}}</span>
  234. <div class="mainFourImg">
  235. <span class="mainFourImgSpan" :style="getFooterseaSty()">{{item.score}}</span>
  236. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  237. :width="200" trigger="hover" :content="item.matter_heigh_note">
  238. <template #reference>
  239. <img :src="item.matter_heigh === 0 ? cenImg : item.matter_heigh === 1 ? topImg : botImg"
  240. alt="">
  241. </template>
  242. </el-popover>
  243. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  244. :width="200" trigger="hover" :content="item.matter_low_note">
  245. <template #reference>
  246. <img :src="item.matter_low === 0 ? cenImg : item.matter_low === 1 ? topImg : botImg"
  247. alt="">
  248. </template>
  249. </el-popover>
  250. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  251. :width="200" trigger="hover" :content="item.manage_heigh_note">
  252. <template #reference>
  253. <img :src="item.manage_heigh === 0 ? cenImg : item.manage_heigh === 1 ? topImg : botImg"
  254. alt="">
  255. </template>
  256. </el-popover>
  257. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  258. :width="200" trigger="hover" :content="item.manage_low_note">
  259. <template #reference>
  260. <img :src="item.manage_low === 0 ? cenImg : item.manage_low === 1 ? topImg : botImg"
  261. alt="">
  262. </template>
  263. </el-popover>
  264. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  265. :width="200" trigger="hover" :content="item.standard_heigh_note">
  266. <template #reference>
  267. <img :src="item.standard_heigh === 0 ? cenImg : item.standard_heigh === 1 ? topImg : botImg"
  268. alt="">
  269. </template>
  270. </el-popover>
  271. <el-popover placement="right-start" :title="item.company +' '+ item.score"
  272. :width="200" trigger="hover" :content="item.standard_low_note">
  273. <template #reference>
  274. <img :src="item.standard_low === 0 ? cenImg : item.standard_low === 1 ? topImg : botImg"
  275. alt="">
  276. </template>
  277. </el-popover>
  278. </div>
  279. </div>
  280. </div>
  281. </div>
  282. </div>
  283. </el-col>
  284. <el-col :span="5" class="report">
  285. <div class="gateway_report">
  286. <div class="reportTit">
  287. <p :style="winPix === 1.25 || innerWidth < 1800? 'font-size: 16px;':''">通告栏</p>
  288. <el-icon :size="20" color="#3B7AD1" :style="winPix === 1.25 || innerWidth < 1800? 'left: 80px;':''"
  289. @click="watchAllNotification">
  290. <Plus />
  291. </el-icon>
  292. </div>
  293. <div class="reportMain">
  294. <div class="reportMain_msg" v-for="it in noticeData" :key="it.id">
  295. <div class="rightDiv"></div>
  296. <div class="rightTitMsg">
  297. <p @click="watchDetail(it)" style="cursor:pointer">{{it.noticeTitle}}</p>
  298. <div style="margin-top: 5px; display: flex">
  299. <span
  300. style="margin-right: 10px">{{it.createTime.substring(0, it.createTime.indexOf(' '))}}</span>
  301. <span class="rightTwoSpanMsg"
  302. :style="winPix === 1.25 || innerWidth < 1800? 'width: 50%;':''">{{it.releaseDeptName}}</span>
  303. </div>
  304. </div>
  305. </div>
  306. </div>
  307. </div>
  308. </el-col>
  309. </el-row>
  310. <year-from ref="yearFrom"></year-from>
  311. <season-from ref="seasonFrom"></season-from>
  312. <notification-detail ref="notificationDetail"></notification-detail>
  313. <notification-all-data ref="notificationAllData"></notification-all-data>
  314. </div>
  315. </template>
  316. <script>
  317. import cup1 from '../assets/getwayImg/cup1.png'
  318. import cup2 from '../assets/getwayImg/cup2.png'
  319. import cup3 from '../assets/getwayImg/cup3.png'
  320. import topImg from '../assets/getwayImg/topNewS.png'
  321. import botImg from '../assets/getwayImg/botNewS.png'
  322. import cenImg from '../assets/getwayImg/cenNew.png'
  323. import {
  324. apiGetevaluationportallist,
  325. apiGetevaluationportalhomeSeason,
  326. apiGetevaluationCircularDisplaylist
  327. } from '../api/api'
  328. import yearFrom from './gateWay/gatewayNewYearFrom.vue'
  329. import seasonFrom from './gateWay/gatewayNewSeasonFrom.vue'
  330. import notificationDetail from './gateWay/gateWayNotificationDetail.vue'
  331. import NotificationAllData from './gateWay/gateWayNotificationAllData.vue'
  332. export default {
  333. components: {
  334. yearFrom,
  335. seasonFrom,
  336. notificationDetail,
  337. NotificationAllData
  338. },
  339. data() {
  340. return {
  341. noticeData: [],
  342. cupDataYearArr: {
  343. section: [],
  344. integration: []
  345. },
  346. cupDataSeasonArr: {
  347. section: [],
  348. integration: []
  349. },
  350. cupFootMsgArr: [],
  351. matterMsg: ['加分事项', '扣分事项', '管理加分', '管理扣分', '高于基准', '低于基准'],
  352. topImg: topImg,
  353. botImg: botImg,
  354. cenImg: cenImg,
  355. changeNewYear: '',
  356. changeYear: '',
  357. seasonStr: '',
  358. seasonArr: ['第一季度', '第二季度', '第三季度'],
  359. winPix: window.devicePixelRatio,
  360. innerWidth: window.innerWidth
  361. }
  362. },
  363. created() {
  364. this.cupFootMsgArr = [{
  365. level: 'A',
  366. points: '134',
  367. img: cup1,
  368. name: '大港电厂(广安津能)'
  369. },
  370. {
  371. level: 'A',
  372. points: '134',
  373. img: cup2,
  374. name: '怀安热电'
  375. }
  376. ]
  377. },
  378. mounted() {
  379. if (!this.$route?.query?.taskInfo) {
  380. this.getYearSeasonData()
  381. this.getDeptNoticeData()
  382. } else {
  383. this.$router.push({ path: "/taskCenter", query: this.$route.query})
  384. }
  385. },
  386. methods: {
  387. // 获取首页年份和季度数据
  388. getYearSeasonData() {
  389. let that = this
  390. apiGetevaluationportalhomeSeason().then(datas => {
  391. if (datas.success) {
  392. if (datas.data) {
  393. that.changeNewYear = datas.data.newyear
  394. that.changeYear = datas.data.year
  395. if (datas.data.season === '1') {
  396. that.seasonStr = '第一季度'
  397. } else if (datas.data.season === '2') {
  398. that.seasonStr = '第二季度'
  399. } else {
  400. that.seasonStr = '第三季度'
  401. }
  402. }
  403. } else {
  404. that.changeYear = (new Date().getFullYear() - 1).toString()
  405. that.seasonStr = '第一季度'
  406. }
  407. that.getGateWayData()
  408. })
  409. },
  410. getDeptNoticeData() {
  411. let that = this
  412. let userMes = JSON.parse(window.sessionStorage.getItem('user'))
  413. if (userMes.deptId) {
  414. let params = {
  415. deptId: userMes.deptId,
  416. noticeTitle: ''
  417. }
  418. apiGetevaluationCircularDisplaylist(params).then(datas => {
  419. if (datas && datas.data) {
  420. that.noticeData = datas.data
  421. }
  422. })
  423. }
  424. },
  425. getPos() {
  426. if (this.winPix === 1.25 || this.innerWidth < 1800) {
  427. return 'top: -15%;'
  428. }
  429. },
  430. getPickerSty() {
  431. if (this.winPix === 1.25 || this.innerWidth < 1800) {
  432. return 'margin: 5px 0 0 20px;'
  433. }
  434. },
  435. getMainOneSty() {
  436. if (this.winPix === 1.25 || this.innerWidth < 1800) {
  437. return 'font-size: 14px'
  438. }
  439. },
  440. getFooterOneSty() {
  441. if (this.winPix === 1.25 || this.innerWidth < 1800) {
  442. return 'font-size: 12px;line-height: 12px;'
  443. }
  444. },
  445. getFooter12Sty() {
  446. if (this.winPix === 1.25 || this.innerWidth < 1800) {
  447. return 'font-size: 12px;width:25%'
  448. }
  449. },
  450. getFooterseaSty() {
  451. if (this.winPix === 1.25 || this.innerWidth < 1800) {
  452. return 'width:10%'
  453. }
  454. },
  455. getfooterSpan() {
  456. if (this.winPix === 1.25 || this.innerWidth < 1800) {
  457. return 'width: 3.4vw;padding: 5px 3px 0;'
  458. }
  459. },
  460. changeNewYearFn(val) {
  461. this.changeNewYear = val
  462. this.changeComYearFn()
  463. },
  464. changeYearFn(val) {
  465. this.changeYear = val
  466. this.changeComYearFn()
  467. },
  468. changeComYearFn() {
  469. this.cupDataYearArr = {
  470. section: [],
  471. integration: []
  472. }
  473. this.cupDataSeasonArr = {
  474. section: [],
  475. integration: []
  476. }
  477. this.getGateWayData()
  478. },
  479. watchDetail(row) {
  480. this.$refs.notificationDetail.init(row)
  481. },
  482. watchAllNotification() {
  483. this.$refs.notificationAllData.init()
  484. },
  485. arrowLeft() {
  486. if (this.seasonStr === '第一季度') {
  487. this.seasonStr = '第三季度'
  488. } else if (this.seasonStr === '第二季度') {
  489. this.seasonStr = '第一季度'
  490. } else if (this.seasonStr === '第三季度') {
  491. this.seasonStr = '第二季度'
  492. }
  493. this.cupDataYearArr = {
  494. section: [],
  495. integration: []
  496. }
  497. this.cupDataSeasonArr = {
  498. section: [],
  499. integration: []
  500. }
  501. this.getGateWayData()
  502. },
  503. arrowRight() {
  504. if (this.seasonStr === '第一季度') {
  505. this.seasonStr = '第二季度'
  506. } else if (this.seasonStr === '第二季度') {
  507. this.seasonStr = '第三季度'
  508. } else if (this.seasonStr === '第三季度') {
  509. this.seasonStr = '第一季度'
  510. }
  511. this.cupDataYearArr = {
  512. section: [],
  513. integration: []
  514. }
  515. this.cupDataSeasonArr = {
  516. section: [],
  517. integration: []
  518. }
  519. this.getGateWayData()
  520. },
  521. // 获取首页数据
  522. getGateWayData() {
  523. let that = this
  524. let params = {
  525. binSection: '',
  526. newyear: that.changeNewYear,
  527. year: that.changeYear,
  528. season: that.seasonStr === '第一季度' ? '1' : that.seasonStr === '第二季度' ? '2' : '3'
  529. }
  530. console.log(111,params)
  531. console.log(222,that.seasonStr)
  532. apiGetevaluationportallist(params).then(datas => {
  533. if (datas && datas.data) {
  534. let secArr = ['HD', 'SD', 'XNYFG', 'GJYW', 'MDYTH']
  535. secArr.forEach(item => {
  536. if (Object.keys(datas.data.year).length>0) {
  537. for (let i in datas.data.year) {
  538. let it = datas.data.year[i]
  539. if (item === i && i !== 'MDYTH') {
  540. let gradeA = 0
  541. let gradeB = 0
  542. let gradeC = 0
  543. let gradeD = 0
  544. let tableData = []
  545. it.forEach((iv, index) => {
  546. if (index < 3) {
  547. let obj = iv
  548. if (index === 0) {
  549. obj.img = cup1
  550. } else if (index === 1) {
  551. obj.img = cup2
  552. } else if (index === 2) {
  553. obj.img = cup3
  554. }
  555. tableData.push(iv)
  556. }
  557. if (iv.grade === 'A') {
  558. gradeA++
  559. } else if (iv.grade === 'B') {
  560. gradeB++
  561. } else if (iv.grade === 'C') {
  562. gradeC++
  563. } else if (iv.grade === 'D') {
  564. gradeD++
  565. }
  566. })
  567. let obj = {
  568. name: item === 'HD' ? '火电板块' : item === 'SD' ? '水电板块' :
  569. item === 'XNYFG' ? '新能源' : '海外业务',
  570. nameEn: item,
  571. echartsData: {
  572. allNum: it.length,
  573. echarts: [{
  574. value: gradeA,
  575. name: 'A类'
  576. },
  577. {
  578. value: gradeB,
  579. name: 'B类'
  580. },
  581. {
  582. value: gradeC,
  583. name: 'C类'
  584. },
  585. {
  586. value: gradeD,
  587. name: 'D类'
  588. }
  589. ]
  590. },
  591. tableDatas: tableData,
  592. allTableData: it,
  593. section: [],
  594. sectionAll: []
  595. }
  596. that.cupDataYearArr.section.push(obj)
  597. } else if (item === i && i === 'MDYTH') {
  598. it.forEach((iv, index) => {
  599. if (index < 2) {
  600. if (index === 0) {
  601. iv.img = cup1
  602. } else if (index === 1) {
  603. iv.img = cup2
  604. }
  605. that.cupDataYearArr.integration.push(iv)
  606. }
  607. })
  608. }
  609. }
  610. } else {
  611. for (let i in datas.data.season) {
  612. let it = datas.data.season[i]
  613. if (item === i && i !== 'MDYTH') {
  614. let obj = {
  615. name: item === 'HD' ? '火电板块' : item === 'SD' ? '水电板块' :
  616. item === 'XNYFG' ? '新能源' : '海外业务',
  617. nameEn: item,
  618. section: [],
  619. }
  620. that.cupDataYearArr.section.push(obj)
  621. }
  622. }
  623. }
  624. })
  625. that.cupDataYearArr.section.forEach(item => {
  626. for (let i in datas.data.season) {
  627. let it = datas.data.season[i]
  628. if (item.nameEn === i) {
  629. it.forEach((iv, index) => {
  630. if (index < 3) {
  631. item.section.push(iv)
  632. }
  633. })
  634. item.sectionAll = it
  635. }
  636. }
  637. })
  638. if (datas.data.season['MDYTH']) {
  639. datas.data.season['MDYTH'].forEach((item, index) => {
  640. if (index < 2) {
  641. that.cupDataSeasonArr.integration.push(item)
  642. }
  643. })
  644. }
  645. console.log(that.cupDataYearArr)
  646. console.log(that.cupDataSeasonArr)
  647. this.$nextTick(() => {
  648. that.getEcharts(that.cupDataYearArr.section)
  649. })
  650. }
  651. })
  652. },
  653. getEcharts(datas) {
  654. datas.forEach((item, index) => {
  655. this.getEchartsData(item.echartsData.echarts, 'pieChart' + index)
  656. })
  657. },
  658. getEchartsData(data, name) {
  659. let total = 0
  660. data.forEach(it => {
  661. total += it.value
  662. })
  663. let option = {
  664. color: ['#F65177', '#50C14E', '#5093E1', '#9DA5BE'],
  665. tooltip: {
  666. trigger: 'item'
  667. },
  668. series: [{
  669. name: '年度榜',
  670. type: 'pie',
  671. radius: ['50%', '70%'],
  672. avoidLabelOverlap: false,
  673. label: {
  674. show: true,
  675. position: 'center',
  676. formatter: () => {
  677. return total
  678. },
  679. fontSize: 16,
  680. fontWeight: 600
  681. },
  682. // emphasis: {
  683. // label: {
  684. // show: true,
  685. // fontSize: 10,
  686. // fontWeight: 'bold'
  687. // }
  688. // },
  689. labelLine: {
  690. show: false
  691. },
  692. data: data
  693. }]
  694. };
  695. // 基于准备好的dom,初始化echarts实例
  696. let dom = document.getElementById(name);
  697. dom.removeAttribute("_echarts_instance_")
  698. let myChart = this.$echarts.init(dom);
  699. myChart.setOption(option);
  700. window.addEventListener("resize", function () {
  701. myChart.resize()
  702. })
  703. },
  704. yearSeeMore(name, type) {
  705. if (type === 'year') {
  706. this.$refs.yearFrom.init(name, this.changeNewYear, this.changeYear, this.seasonStr)
  707. } else {
  708. this.$refs.seasonFrom.init(name, this.changeNewYear, this.changeYear, this.seasonStr)
  709. }
  710. }
  711. }
  712. }
  713. </script>
  714. <style lang="less">
  715. .gatewayNewPage {
  716. height: 93vh;
  717. width: 87vw;
  718. background: #EDEFF5;
  719. padding: 15px 20px;
  720. .quarter {
  721. background: #fff;
  722. border-radius: 10px;
  723. height: 100%;
  724. // padding-right: 15px;
  725. .searchFn {
  726. // height: 50px;
  727. height: 5vh;
  728. display: flex;
  729. border-bottom: 1px solid #E1E3EA;
  730. .searchFn_left{
  731. width: 43%;
  732. }
  733. .searchFn_right{
  734. width: 57%;
  735. position: relative;
  736. .quarterChoose {
  737. position: absolute;
  738. left: 33%;
  739. top: 15px;
  740. width: 225px;
  741. display: flex;
  742. justify-content: space-around;
  743. .choose {
  744. position: relative;
  745. top: -1px;
  746. }
  747. .el-icon {
  748. cursor: pointer;
  749. }
  750. }
  751. }
  752. .el-date-editor--year {
  753. width: 130px;
  754. margin: 10px 0 0 20px;
  755. .el-input__wrapper {
  756. background: #2C7EDC;
  757. height: 30px;
  758. .el-input__prefix,
  759. .el-input__inner,
  760. .el-input__suffix {
  761. color: #fff;
  762. }
  763. }
  764. }
  765. ::-webkit-input-placeholder {
  766. color: #fff;
  767. }
  768. }
  769. .tableHeader {
  770. display: flex;
  771. border-bottom: 1px solid #E1E3EA;
  772. // height: 75px;
  773. height: 9vh;
  774. width: 100%;
  775. .headerComTit {
  776. // height: 40px;
  777. height: 5vh;
  778. border-bottom: 1px solid #E1E3EA;
  779. span {
  780. font-size: 14px;
  781. color: #3B7AD1;
  782. }
  783. }
  784. .headerNameTit {
  785. display: flex;
  786. justify-content: space-between;
  787. padding: 8px 10px;
  788. font-size: 12px;
  789. color: #414141;
  790. .headerNameTit_left {
  791. width: 60%;
  792. }
  793. .headerNameTit_right {
  794. width: 40%;
  795. display: flex;
  796. justify-content: center;
  797. }
  798. }
  799. .headerOne {
  800. // width: 35px;
  801. width: 3%;
  802. background: #184FB4;
  803. }
  804. .headerTwo {
  805. // width: 150px;
  806. width: 12%;
  807. border-right: 1px solid #E1E3EA;
  808. .headerTwoTit {
  809. position: relative;
  810. top: 10px;
  811. left: 30%;
  812. }
  813. }
  814. .headerThree {
  815. // width: 350px;
  816. width: 28%;
  817. border-right: 1px solid #E1E3EA;
  818. .headerThreeTit {
  819. position: relative;
  820. top: 10px;
  821. left: 40%;
  822. }
  823. }
  824. .headerFour {
  825. // width: calc(100% - 535px);
  826. width: 57%;
  827. .headerFourTit {
  828. position: relative;
  829. top: 10px;
  830. left: 40%;
  831. }
  832. .headerNameForeTit {
  833. display: flex;
  834. justify-content: space-between;
  835. padding: 8px 10px;
  836. font-size: 12px;
  837. color: #414141;
  838. .headerNameForeTit_left {
  839. width: 30%;
  840. }
  841. .headerNameForeTit_right {
  842. width: 72%;
  843. display: flex;
  844. justify-content: space-between;
  845. }
  846. }
  847. }
  848. }
  849. .tableMain {
  850. display: flex;
  851. border-bottom: 1px solid #E1E3EA;
  852. // height: 150px;
  853. height: 16vh;
  854. .mainOne {
  855. // width: 35px;
  856. width: 3%;
  857. background: #184FB4;
  858. span {
  859. display: inline-block;
  860. width: 20px;
  861. margin: 0 auto;
  862. line-height: 20px;
  863. font-size: 16px;
  864. font-weight: bold;
  865. color: #fff;
  866. position: relative;
  867. top: 20%;
  868. left: 25%;
  869. }
  870. }
  871. .mainTwo {
  872. // width: 149px;
  873. width: 12%;
  874. border-right: 1px solid #E1E3EA;
  875. position: relative;
  876. @media screen and (max-width: 1540px) and (min-width: 1300px) {
  877. .mainTwoMsg {
  878. top: -15%;
  879. }
  880. }
  881. .mainTwoMsg {
  882. position: relative;
  883. .mainTwoComColor {
  884. display: inline-block;
  885. width: 6px;
  886. height: 6px;
  887. border-radius: 20px;
  888. margin-left: 15px;
  889. position: relative;
  890. top: -1px;
  891. }
  892. .mainTwoComTit {
  893. font-size: 14px;
  894. display: inline-block;
  895. margin-left: 5px;
  896. }
  897. }
  898. .echartsNum {
  899. font-size: 16px;
  900. font-weight: 600;
  901. position: absolute;
  902. top: 42px;
  903. left: 65px;
  904. }
  905. }
  906. .mainThree {
  907. // width: 350px;
  908. width: 28%;
  909. padding-top: 13px;
  910. border-right: 1px solid #E1E3EA;
  911. position: relative;
  912. .mainMore {
  913. width: 0;
  914. height: 0;
  915. border-top: 10px solid transparent;
  916. border-left: 10px solid #B6BBCB;
  917. border-right: 10px solid transparent;
  918. border-bottom: 10px solid transparent;
  919. position: absolute;
  920. top: -9px;
  921. right: -9px;
  922. transform: rotate(-45deg);
  923. cursor: pointer;
  924. }
  925. .mainThreeMsg {
  926. display: flex;
  927. margin: 0 10px;
  928. width: 100%;
  929. // height: 33px;
  930. height: 3.5vh;
  931. background: #F6F7FA;
  932. margin-bottom: 8px;
  933. padding-left: 10px;
  934. padding-top: 2px;
  935. border-radius: 5px;
  936. img {
  937. width: 20px;
  938. height: 20px;
  939. position: relative;
  940. top: 5px;
  941. margin-right: 10px;
  942. }
  943. .msgProgress {
  944. margin-top: 5px;
  945. display: flex;
  946. width: 90%;
  947. span {
  948. font-size: 14px;
  949. font-family: Microsoft YaHei;
  950. }
  951. span:nth-child(1) {
  952. display: inline-block;
  953. width: 70%;
  954. overflow: hidden;
  955. text-overflow: ellipsis;
  956. white-space: nowrap;
  957. font-weight: 400;
  958. color: #666;
  959. margin-right: 10px;
  960. }
  961. span:nth-child(2) {
  962. font-weight: 600;
  963. margin-right: 30px;
  964. color: #F65177;
  965. }
  966. span:nth-child(3) {
  967. display: inline-block;
  968. width: 20%;
  969. font-weight: 600;
  970. color: #666;
  971. }
  972. }
  973. }
  974. }
  975. .mainFour {
  976. // width: calc(100% - 536px);
  977. width: 57%;
  978. padding-top: 13px;
  979. position: relative;
  980. .mainMore {
  981. width: 0;
  982. height: 0;
  983. border-top: 10px solid transparent;
  984. border-left: 10px solid #B6BBCB;
  985. border-right: 10px solid transparent;
  986. border-bottom: 10px solid transparent;
  987. position: absolute;
  988. top: -9px;
  989. right: -9px;
  990. transform: rotate(-45deg);
  991. cursor: pointer;
  992. }
  993. .mainFourMsg {
  994. display: flex;
  995. justify-content: space-between;
  996. margin: 0 10px;
  997. width: 100%;
  998. // height: 33px;
  999. height: 3.5vh;
  1000. background: #F6F7FA;
  1001. margin-bottom: 8px;
  1002. padding-left: 10px;
  1003. padding-top: 2px;
  1004. border-radius: 5px;
  1005. span {
  1006. font-size: 14px;
  1007. font-family: Microsoft YaHei;
  1008. position: relative;
  1009. top: 6px;
  1010. display: inline-block;
  1011. }
  1012. .mainFourcompany {
  1013. width: 27%;
  1014. overflow: hidden;
  1015. text-overflow: ellipsis;
  1016. white-space: nowrap;
  1017. font-weight: 400;
  1018. color: #666;
  1019. margin-right: 17px;
  1020. }
  1021. .mainFourImg {
  1022. display: flex;
  1023. justify-content: space-between;
  1024. width: 76%;
  1025. .mainFourImgSpan {
  1026. width: 5%;
  1027. font-weight: 600;
  1028. // margin-right: 15px;
  1029. color: #666;
  1030. }
  1031. img {
  1032. width: 20px;
  1033. height: 20px;
  1034. position: relative;
  1035. top: 5px;
  1036. left: -10px;
  1037. // margin-right: 33px;
  1038. // margin-left: 22px;
  1039. }
  1040. }
  1041. }
  1042. }
  1043. }
  1044. .tableFooter {
  1045. display: flex;
  1046. // height: 100px;
  1047. height: 10vh;
  1048. @media screen and (max-width: 1540px) and (min-width: 1300px) {
  1049. .footerOne {
  1050. span {
  1051. font-size: 12px;
  1052. line-height: 12px;
  1053. }
  1054. }
  1055. }
  1056. @media screen and (max-width: 1920px) and (min-width: 1800px) {
  1057. .footerOne {
  1058. span {
  1059. font-size: 16px;
  1060. line-height: 16px;
  1061. }
  1062. }
  1063. }
  1064. .footerOne {
  1065. // width: 35px;
  1066. width: 3%;
  1067. background: #7D8297;
  1068. border-radius: 0 0 0 10px;
  1069. span {
  1070. display: inline-block;
  1071. // width: 20px;
  1072. width: 3%;
  1073. margin: 0 auto;
  1074. // line-height: 16px;
  1075. // font-size: 16px;
  1076. font-weight: bold;
  1077. color: #fff;
  1078. position: relative;
  1079. top: 10px;
  1080. left: 10px;
  1081. }
  1082. }
  1083. .footerTwo {
  1084. // width: 500px;
  1085. width: 40%;
  1086. padding-top: 10px;
  1087. border-right: 1px solid #E1E3EA;
  1088. .footerTwoMsg {
  1089. display: flex;
  1090. margin: 0 10px;
  1091. width: 100%;
  1092. // height: 33px;
  1093. height: 3.5vh;
  1094. background: #F6F7FA;
  1095. margin-bottom: 8px;
  1096. padding-left: 10px;
  1097. // padding-top: 2px;
  1098. border-radius: 5px;
  1099. img {
  1100. width: 20px;
  1101. height: 20px;
  1102. position: relative;
  1103. top: 5px;
  1104. margin-right: 10px;
  1105. }
  1106. .footerProgress {
  1107. margin-top: 5px;
  1108. display: flex;
  1109. width: 91%;
  1110. span {
  1111. font-size: 14px;
  1112. font-family: Microsoft YaHei;
  1113. }
  1114. .footerOneSpan {
  1115. display: inline-block;
  1116. width: 35%;
  1117. overflow: hidden;
  1118. text-overflow: ellipsis;
  1119. white-space: nowrap;
  1120. font-weight: 400;
  1121. color: #666;
  1122. margin-right: 10px;
  1123. }
  1124. .el-progress {
  1125. width: calc(50% - 15px);
  1126. padding-right: 15px;
  1127. position: relative;
  1128. top: -3px;
  1129. .el-progress__text {
  1130. display: none;
  1131. }
  1132. }
  1133. .footerTwoSpan {
  1134. font-weight: 600;
  1135. margin-right: 30px;
  1136. color: #F65177;
  1137. }
  1138. .footerThreeSpan {
  1139. display: inline-block;
  1140. width: 12%;
  1141. font-weight: 600;
  1142. color: #666;
  1143. }
  1144. }
  1145. }
  1146. }
  1147. .footerThree {
  1148. // width: calc(100% - 536px);
  1149. width: 57%;
  1150. padding-top: 10px;
  1151. position: relative;
  1152. .mainMore {
  1153. width: 0;
  1154. height: 0;
  1155. border-top: 10px solid transparent;
  1156. border-left: 10px solid #B6BBCB;
  1157. border-right: 10px solid transparent;
  1158. border-bottom: 10px solid transparent;
  1159. position: absolute;
  1160. top: -9px;
  1161. right: -9px;
  1162. transform: rotate(-45deg);
  1163. cursor: pointer;
  1164. }
  1165. .footerThreeMsg {
  1166. display: flex;
  1167. width: 13%;
  1168. // margin: 0 10px;
  1169. // margin-left: 10px;
  1170. padding: 0 10px;
  1171. margin-bottom: 8px;
  1172. span {
  1173. font-size: 12px;
  1174. font-weight: 400;
  1175. color: #666;
  1176. font-family: Microsoft YaHei;
  1177. }
  1178. .footerImg {
  1179. display: flex;
  1180. border-radius: 5px;
  1181. background: #F6F7FA;
  1182. span {
  1183. display: inline-block;
  1184. // width: 100%;
  1185. // width: 48px;
  1186. width: 3vw;
  1187. // height: 30px;
  1188. height: 3vh;
  1189. padding: 5px 8px 0;
  1190. position: relative;
  1191. top: 2px;
  1192. }
  1193. img {
  1194. width: 20px;
  1195. height: 20px;
  1196. position: relative;
  1197. top: 5px;
  1198. margin-right: 8px;
  1199. position: relative;
  1200. top: 7px;
  1201. }
  1202. }
  1203. }
  1204. .mainFourMsg {
  1205. display: flex;
  1206. justify-content: space-between;
  1207. margin: 0 10px;
  1208. width: 100%;
  1209. // height: 33px;
  1210. height: 3.5vh;
  1211. background: #F6F7FA;
  1212. margin-bottom: 8px;
  1213. padding-left: 10px;
  1214. padding-top: 2px;
  1215. border-radius: 5px;
  1216. span {
  1217. font-size: 14px;
  1218. font-family: Microsoft YaHei;
  1219. position: relative;
  1220. top: 6px;
  1221. display: inline-block;
  1222. }
  1223. .mainFourcompany {
  1224. width: 27%;
  1225. overflow: hidden;
  1226. text-overflow: ellipsis;
  1227. white-space: nowrap;
  1228. font-weight: 400;
  1229. color: #666;
  1230. margin-right: 17px;
  1231. }
  1232. .mainFourImg {
  1233. display: flex;
  1234. justify-content: space-between;
  1235. width: 76%;
  1236. .mainFourImgSpan {
  1237. width: 5%;
  1238. font-weight: 600;
  1239. // margin-right: 15px;
  1240. color: #666;
  1241. }
  1242. img {
  1243. width: 20px;
  1244. height: 20px;
  1245. position: relative;
  1246. top: 5px;
  1247. left: -10px;
  1248. // margin-right: 33px;
  1249. // margin-left: 22px;
  1250. }
  1251. }
  1252. }
  1253. }
  1254. }
  1255. }
  1256. .report {
  1257. margin-left: 20px;
  1258. height: 100%;
  1259. .gateway_report {
  1260. // width: 355px;
  1261. width: 100%;
  1262. background: #fff;
  1263. // margin-right: 30px;
  1264. margin-right: calc(100% - 355px);
  1265. border-radius: 10px;
  1266. padding-bottom: 10px;
  1267. border: 1px solid #D6DBEA;
  1268. .reportTit {
  1269. padding: 21px 25px 10px 25px;
  1270. // background: #E3EFFF;
  1271. border-bottom: 1px solid #D6DBEA;
  1272. border-radius: 10px 10px 0px 0px;
  1273. text-align: center;
  1274. display: flex;
  1275. justify-content: center;
  1276. p {
  1277. font-size: 18px;
  1278. font-family: Microsoft YaHei;
  1279. font-weight: bold;
  1280. color: #3B7AD1;
  1281. }
  1282. .el-icon {
  1283. position: relative;
  1284. left: 120px;
  1285. top: 3px;
  1286. cursor: pointer;
  1287. }
  1288. }
  1289. .reportMain {
  1290. height: 80vh !important;
  1291. overflow-x: hidden;
  1292. overflow-y: auto;
  1293. .reportMain_msg {
  1294. width: 100%;
  1295. display: flex;
  1296. padding: 25px 0 25px 27px;
  1297. border-bottom: 1px solid #D6DBEA;
  1298. .rightDiv {
  1299. width: 4px;
  1300. height: 40px;
  1301. // height: 5vh;
  1302. background: #4883D4;
  1303. border-radius: 2px;
  1304. position: relative;
  1305. top: 2px;
  1306. }
  1307. .rightTitMsg {
  1308. margin-left: 15px;
  1309. width: calc(100% - 20px);
  1310. p {
  1311. // width: 300px;
  1312. width: 95%;
  1313. overflow: hidden;
  1314. text-overflow: ellipsis;
  1315. white-space: nowrap;
  1316. font-size: 16px;
  1317. font-family: Microsoft YaHei;
  1318. font-weight: bold;
  1319. color: #333333;
  1320. }
  1321. span {
  1322. font-size: 14px;
  1323. font-family: Microsoft YaHei;
  1324. font-weight: 400;
  1325. color: #8991B0;
  1326. display: inline-block;
  1327. }
  1328. .rightTwoSpanMsg {
  1329. width: 60%;
  1330. overflow: hidden;
  1331. text-overflow: ellipsis;
  1332. white-space: nowrap;
  1333. }
  1334. }
  1335. }
  1336. }
  1337. }
  1338. }
  1339. }
  1340. </style>