index.html 15 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="utf-8" />
  5. <meta http-equiv="X-UA-Compatible" content="IE=edge" />
  6. <meta name="viewport" content="width=device-width, initial-scale=1" />
  7. <!-- 引入样式 -->
  8. <link rel="stylesheet" href="./styles/element-ui@2.15.9.css" />
  9. <link rel="stylesheet" href="./styles/normalize.css" />
  10. <link rel="stylesheet" href="./styles/index.css" />
  11. <!-- 引入js -->
  12. <script src="./libs/vue@2.7.10.js"></script>
  13. <!-- <script src="https://unpkg.com/@jiaminghi/data-view/dist/datav.min.vue.js"></script> -->
  14. <script src="./libs/echarts.min.js"></script>
  15. <script src="./libs/datav.min.js"></script>
  16. <script src="./libs/element-ui@2.15.9.js"></script>
  17. <script src="./libs/axios.min.js"></script>
  18. <script src="./libs/lodash.min.js"></script>
  19. <script src="./js/request.js"></script>
  20. <script src="./js/data.js"></script>
  21. <script src="./js/zhb.js"></script>
  22. <script src="./js/li.js"></script>
  23. <script src="./js/fjx.js"></script>
  24. <script src="./libs/echarts-tooltip-carousel.js"></script>
  25. </head>
  26. <body>
  27. <div id="app" v-cloak @click="showTipClose">
  28. <header class="my-header">
  29. <span @click.stop="handleTitleShow('title.png')" style="cursor: pointer;">国有资本数智化平台人力资源系统</span>
  30. <span class="right">{{time}}</span>
  31. </header>
  32. <div class="main">
  33. <div class="left">
  34. <dv-border-box-8 :dur="10" style="flex: 1;">
  35. <div class="my-panel">
  36. <div class="panel-title flex-between ">
  37. <span class="text">定机构</span>
  38. <div>
  39. <span class="tip-window" @click.stop="handleShowTip(0,'focus')">改革成效</span>
  40. <span class="tip-window" @click.stop="handleShowTip(0,'analysis')">智能分析</span>
  41. </div>
  42. </div>
  43. <div class="content flex">
  44. <div ref="echartL1" style="flex: 1;height: 100%;"></div>
  45. <div ref="echartL2" style="flex: 1;height: 100%;"></div>
  46. </div>
  47. </div>
  48. </dv-border-box-8>
  49. <dv-border-box-8 :dur="11" style="flex: 1;">
  50. <div class="my-panel">
  51. <div class="panel-title flex-between">
  52. <span class="text">定职数</span>
  53. <div>
  54. <span class="tip-window" @click.stop="handleShowTip(1,'focus')">改革成效</span>
  55. <span class="tip-window" @click.stop="handleShowTip(1,'analysis')">智能分析</span>
  56. </div>
  57. </div>
  58. <div class="content flex">
  59. <div ref="echartL3" style="flex: 1;height: 100%;"></div>
  60. <div style="flex: 1;height: 100%; position: relative;">
  61. <div ref="echartL4" style="height: 100%; width: 100%;"></div>
  62. <div class="icon" @click.stop="handleShowTip2(0)">?</div>
  63. </div>
  64. </div>
  65. </div>
  66. </dv-border-box-8>
  67. <dv-border-box-8 :dur="12" style="flex: 2;">
  68. <div class="my-panel">
  69. <div class="panel-title flex-between">
  70. <span class="text">定员额</span>
  71. <div>
  72. <span class="tip-window" @click.stop="handleShowTip(2,'focus')">改革成效</span>
  73. <span class="tip-window" @click.stop="handleShowTip(2,'analysis')">智能分析</span>
  74. </div>
  75. </div>
  76. <div class="content flex flex-wrap">
  77. <div ref="echartL5" style="flex: 0 0 49.9%;height: 50%;"></div>
  78. <div ref="echartL6" style="flex: 0 0 49.9%;height: 50%;"></div>
  79. <div ref="echartL7" style="flex: 0 0 49.9%;height: 50%;"></div>
  80. <div ref="echartL8" style="flex: 0 0 49.9%;height: 50%;"></div>
  81. </div>
  82. </div>
  83. </dv-border-box-8>
  84. </div>
  85. <div class="center">
  86. <div class="top" v-if="centerData">
  87. <div class="box">
  88. <div>
  89. <span class="tip-window2" @click.stop="handleTitleShow('cxdjsms.png')">创新的建设模式</span>
  90. </div>
  91. <div class="box-content">
  92. <img src="./images/center-top1.png" />
  93. <div>
  94. <p>架构数</p>
  95. <p><i style="color: #45DAD1">{{numFormat(centerData.info.value1)}}</i></p>
  96. </div>
  97. </div>
  98. </div>
  99. <div class="box">
  100. <div>
  101. <span class="tip-window2" @click.stop="handleTitleShow('ctdqjjc.png')">穿透的全局监测</span>
  102. </div>
  103. <div class="box-content">
  104. <img src="./images/center-top2.png" />
  105. <div>
  106. <p>岗位数</p>
  107. <p><i style="color: #8BA2FF">{{numFormat(centerData.info.value2)}}</i></p>
  108. </div>
  109. </div>
  110. </div>
  111. <div class="box">
  112. <div>
  113. <span class="tip-window2" @click.stop="handleTitleShow('lxdszpt.png')">领先的数智平台</span>
  114. </div>
  115. <div class="box-content">
  116. <img src="./images/center-top3.png" @click.stop="handleTitleShow('zrs.png')" style=" cursor: pointer;"/>
  117. <div @click.stop="handleTitleShow('zrs.png')" style=" cursor: pointer;">
  118. <p>总人数</p>
  119. <p><i style="color: #69C0FF">{{numFormat(centerData.info.value3)}}</i></p>
  120. </div>
  121. </div>
  122. </div>
  123. </div>
  124. <dv-border-box-8 :dur="10">
  125. <div class="my-panel" v-if="centerData">
  126. <div class="panel-title">
  127. <span class="text">六定改革成效</span>
  128. </div>
  129. <div class="content flex" style="padding: 10px;">
  130. <div class="box-center">
  131. <div class="t alignCenter">
  132. <p>{{numFormat(centerData.changeInfo[0].value1)}}<span>%</span></p>
  133. <p>总部机构压缩率</p>
  134. </div>
  135. <div class="flex">
  136. <div class="alignCenter" @click.stop="handleTitleShow('ggqzbjgs.png')" style=" cursor: pointer;">
  137. <p style="color:#FBE139">{{numFormat(centerData.changeInfo[0].value2)}}</p>
  138. <p>改革前总部机构平均数</p>
  139. </div>
  140. <div class="alignCenter">
  141. <p style="color:#17AC76">{{numFormat(centerData.changeInfo[0].value3)}}</p>
  142. <p>改革后总部机构平均数
  143. </p>
  144. </div>
  145. </div>
  146. </div>
  147. <!-- <div class="box-center">
  148. <div class="t">
  149. <p>{{centerData.changeInfo[1].value1}}<span>%</span></p>
  150. <p>中层管理人数压缩率</p>
  151. </div>
  152. <div class="flex">
  153. <div>
  154. <p style="color:#FBE139">{{numFormat(centerData.changeInfo[1].value2)}}</p>
  155. <p>改革前中层管理人数</p>
  156. </div>
  157. <div>
  158. <p style="color:#17AC76">{{numFormat(centerData.changeInfo[1].value3)}}</p>
  159. <p>改革后中层管理人数</p>
  160. </div>
  161. </div>
  162. </div> -->
  163. <div class="box-center">
  164. <div class="alignCenter">
  165. <p>{{numFormat(centerData.changeInfo[2].value1)}}<span>%</span></p>
  166. <p>在册职工压缩率</p>
  167. </div>
  168. <div class="flex">
  169. <div class="alignCenter" @click.stop="handleTitleShow('ggqzczg.png')" style=" cursor: pointer;">
  170. <p style="color:#FBE139">{{numFormat(centerData.changeInfo[2].value2)}}</p>
  171. <p>改革前在册职工数</p>
  172. </div>
  173. <div class="alignCenter">
  174. <p style="color:#17AC76">{{centerData.changeInfo[2].value3}}<span>万</span></p>
  175. <p>在册职工压缩数</p>
  176. </div>
  177. </div>
  178. </div>
  179. <div class="box-center">
  180. <div class="t alignCenter">
  181. <p>{{numFormat(centerData.changeInfo[1].value1)}}<span>%</span></p>
  182. <p>在岗职工薪酬增长率</p>
  183. </div>
  184. <div class="flex">
  185. <div class="alignCenter" @click.stop="handleTitleShow('ggqzgzgpjxc.png')" style=" cursor: pointer;">
  186. <p style="color:#FBE139">{{numFormat(centerData.changeInfo[1].value2)}}<span>万元</span></p>
  187. <p>改革前在岗职工平均薪酬</p>
  188. </div>
  189. <div class="alignCenter">
  190. <p style="color:#17AC76">{{numFormat(centerData.changeInfo[1].value3)}}<span>万元</span></p>
  191. <p>改革后在岗职工平均薪酬</p>
  192. </div>
  193. </div>
  194. </div>
  195. </div>
  196. </div>
  197. </dv-border-box-8>
  198. <dv-border-box-8 :dur="10">
  199. <div class="my-panel">
  200. <div class="panel-title flex-between">
  201. <span class="text">核心指标监测</span>
  202. <div>
  203. <span class="tip-window" @click.stop="handleShowTip(3,'focus')">改革成效</span>
  204. <span class="tip-window" @click.stop="handleShowTip(3,'analysis')">智能分析</span>
  205. </div>
  206. </div>
  207. <div class="content flex">
  208. <div style="flex: 1;height: 100%; position: relative;">
  209. <div ref="echartC1" style="flex: 1;height: 100%;"></div>
  210. <div class="icon" @click.stop="handleShowTip2(1)">?</div>
  211. </div>
  212. <div ref="echartC2" style="flex: 1;height: 100%;"></div>
  213. </div>
  214. </div>
  215. </dv-border-box-8>
  216. <dv-border-box-8 :dur="10">
  217. <div class="my-panel">
  218. <div class="panel-title">
  219. <span class="text">分析预警中心</span>
  220. </div>
  221. <div class="content yujing">
  222. <div class="flex1">
  223. <p class="s-title main-color">工作台分析</p>
  224. <dv-scroll-board :config="storageRecordConfig" class="content" />
  225. </div>
  226. <div class="flex1">
  227. <p class="s-title main-color">数据库预警</p>
  228. <dv-scroll-board :config="storageRecordConfig2" class="content" />
  229. </div>
  230. </div>
  231. </div>
  232. </dv-border-box-8>
  233. </div>
  234. <div class="right">
  235. <dv-border-box-8 :dur="10" style="flex: 2">
  236. <div class="my-panel">
  237. <div class="panel-title flex-between">
  238. <span class="text">定机制</span>
  239. <div>
  240. <span class="tip-window" @click.stop="handleShowTip(4,'focus')">改革成效</span>
  241. <span class="tip-window" @click.stop="handleShowTip(4,'analysis')">智能分析</span>
  242. </div>
  243. </div>
  244. <div class="content flex flex-wrap">
  245. <div ref="echartR1" style="flex: 0 0 49.9%;height: 50%;"></div>
  246. <div ref="echartR2" style="flex: 0 0 49.9%;height: 50%;"></div>
  247. <div ref="echartR3" style="flex: 0 0 49.9%;height: 50%;"></div>
  248. <div ref="echartR4" style="flex: 0 0 49.9%;height: 50%;"></div>
  249. </div>
  250. </div>
  251. </dv-border-box-8>
  252. <dv-border-box-8 :dur="11" style="flex: 1">
  253. <div class="my-panel">
  254. <div class="panel-title flex-between">
  255. <span class="text">定薪酬</span>
  256. <div>
  257. <!-- <span class="tip-window" @click.stop="handlepaymentShow">改革成效</span> -->
  258. <span class="tip-window" @click.stop="handleShowTip(5,'focus')">改革成效</span>
  259. <span class="tip-window" @click.stop="handleShowTip(5,'analysis')">智能分析</span>
  260. </div>
  261. </div>
  262. <div class="content flex">
  263. <div ref="echartR5" style="flex: 1;height: 100%;"></div>
  264. <div ref="echartR6" style="flex: 1;height: 100%;"></div>
  265. </div>
  266. </div>
  267. </dv-border-box-8>
  268. <dv-border-box-8 :dur="12" style="flex: 1">
  269. <div class="my-panel">
  270. <div class="panel-title flex-between">
  271. <span class="text">定任期</span>
  272. <div>
  273. <span class="tip-window" @click.stop="handleShowTip(6,'focus')">改革成效</span>
  274. <span class="tip-window" @click.stop="handleShowTip(6,'analysis')">智能分析</span>
  275. </div>
  276. </div>
  277. <div class="content flex">
  278. <div ref="echartR7" style="flex: 1;height: 100%;"></div>
  279. <div ref="echartR8" style="flex: 1;height: 100%;"></div>
  280. </div>
  281. </div>
  282. </dv-border-box-8>
  283. </div>
  284. </div>
  285. <div class="footer">
  286. <!-- <a class="item" v-for="(item,index) in companyList.slice(0, 8)" :key="index" -->
  287. <a class="item" v-for="(item,index) in companyList"
  288. style="display: flex;align-items: center;justify-content: center;" :key="index"
  289. @click="handleGoPage(item.id,item.name)"><img v-if="item.orgLogoNum" :src="`./images/logos/${item.orgLogoNum}.png`"></img>
  290. {{item.name}}</a>
  291. <!-- <div style="font-weight: bold;display: flex;align-items: center;flex-shrink: 0;position: absolute;right: -20px;bottom: 30%;" v-if="companyList.length>8"><span>. . .</span>
  292. </div> -->
  293. </div>
  294. <!-- 公共弹窗 -->
  295. <div class="tip" @click="showTip = false" v-if="showTip && tipNum != 3">
  296. <div class="tip-box">
  297. <div class="tip-content">
  298. <div class="btm10" v-for="(item,index) in tipData[tipNum]" :key="index"> {{item}}</div>
  299. </div>
  300. </div>
  301. </div>
  302. <!-- 问号弹窗 -->
  303. <div class="tip" @click="showTip2 = false" v-if="showTip2">
  304. <div class="tip-box" style="left:calc( 50% + 1300px )">
  305. <div class="tip-content">
  306. <div class="btm10" v-for="(item,index) in tipData2[tipNum]" :key="index"> {{item}}</div>
  307. </div>
  308. </div>
  309. </div>
  310. <!-- 核心指标监测专属 -->
  311. <div class="tip" @click="showTip = false" v-if="showTip && tipNum == 3">
  312. <div class="tip-box" style="left:calc( 50% + 1300px )">
  313. <div class="tip-content">
  314. <div class="btm10" v-for="(item,index) in tipData[tipNum]" :key="index"> {{item}}</div>
  315. </div>
  316. </div>
  317. </div>
  318. <!--标题弹窗 -->
  319. <div class="tip" v-if="titleShow">
  320. <div class="tip-box-img">
  321. <div class="tip-content-img">
  322. <img :src="`./images/pop/${imgPop}`" alt="" style="width:93%;">
  323. </div>
  324. </div>
  325. </div>
  326. </div>
  327. <script src="./js/index.js"></script>
  328. </body>
  329. </html>