index.vue 40 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964
  1. <template>
  2. <div class="dashboard-editor-container">
  3. <!--超级管理员10000√ 个人会员1× 政务会员2× 企业会员3× 调研员4×-->
  4. <div v-if="userType == 10000">
  5. <el-row :gutter="32">
  6. <el-col :xs="24" :sm="24" :lg="24">
  7. <div class="topDataBox">
  8. <div class="topDataBoxTitle">
  9. <div class="chatIconBox cibStyle1">
  10. <img src="@/assets/index/top_time.png">
  11. </div>
  12. <div class="topDataBoxTitleText">待审核列表</div>
  13. </div>
  14. <div class="topDataBoxList" v-if="indexData.apply">
  15. <div class="topDataLi1">
  16. <div class="topDataMain">
  17. <span @click="goToList(1)">待审核资讯</span>
  18. <span @click="goToList(1)">{{indexData.apply.article}}</span>
  19. </div>
  20. <div class="topDataMain">
  21. <span @click="goToList(8)">待审核广告</span>
  22. <span @click="goToList(8)">{{indexData.apply.order}}</span>
  23. </div>
  24. </div>
  25. <div class="topDataLi2">
  26. <div class="topDataMainCenter">
  27. <span @click="goToList(2)">待审核商品</span>
  28. <span @click="goToList(2)">{{indexData.apply.good}}</span>
  29. </div>
  30. <div class="topDataMainCenter">
  31. <span @click="goToList(3)">待审核书刊音像</span>
  32. <span @click="goToList(3)">{{indexData.apply.book}}</span>
  33. </div>
  34. </div>
  35. <div class="topDataLi3">
  36. <div class="topDataMainCenter">
  37. <span @click="goToList(4)">待审核招聘</span>
  38. <span @click="goToList(4)">{{indexData.apply.jobRecruiting}}</span>
  39. </div>
  40. <div class="topDataMainCenter">
  41. <span @click="goToList(5)">待审核求职</span>
  42. <span @click="goToList(5)">{{indexData.apply.jobHunting}}</span>
  43. </div>
  44. </div>
  45. <div class="topDataLi4">
  46. <div class="topDataMain">
  47. <span @click="goToList(6)">待审核行政通知</span>
  48. <span @click="goToList(6)">{{indexData.apply.notice}}</span>
  49. </div>
  50. <div class="topDataMain">
  51. <span @click="goToList(7)">待审核行政投诉</span>
  52. <span @click="goToList(7)">{{indexData.apply.complaint}}</span>
  53. </div>
  54. </div>
  55. </div>
  56. </div>
  57. </el-col>
  58. </el-row>
  59. <el-row :gutter="32">
  60. <el-col :xs="24" :sm="24" :lg="6">
  61. <div class="topWindowBox">
  62. <div class="twbTitle">
  63. <div class="twbIconbg bg1">
  64. <img src="@/assets/index/topIcon1.png" />
  65. </div>
  66. 网站数量
  67. </div>
  68. <div class="twbNumber">{{indexData.website.count}}</div>
  69. <!-- <div class="twbStatus"><img src="@/assets/index/arrow-up.png"/> +12% <span>较上周</span></div> -->
  70. </div>
  71. </el-col>
  72. <el-col :xs="24" :sm="24" :lg="6">
  73. <div class="topWindowBox">
  74. <div class="twbTitle">
  75. <div class="twbIconbg bg2">
  76. <img src="@/assets/index/topIcon2.png" />
  77. </div>
  78. 栏目数量
  79. </div>
  80. <div class="twbNumber">{{indexData.category.count}}</div>
  81. <!-- <div class="twbStatus"><img src="@/assets/index/arrow-up.png"/> +18% <span>较昨天</span></div> -->
  82. </div>
  83. </el-col>
  84. <el-col :xs="24" :sm="24" :lg="6">
  85. <div class="topWindowBox">
  86. <div class="twbTitle">
  87. <div class="twbIconbg bg3">
  88. <img src="@/assets/index/topIcon3.png" />
  89. </div>
  90. 资讯发布总数量
  91. </div>
  92. <div class="twbNumber">{{indexData.article.count}}</div>
  93. </div>
  94. </el-col>
  95. <el-col :xs="24" :sm="24" :lg="6">
  96. <div class="topWindowBox">
  97. <div class="twbTitle">
  98. <div class="twbIconbg bg4">
  99. <img src="@/assets/index/topIcon4.png" />
  100. </div>
  101. 商品发布总数量
  102. </div>
  103. <div class="twbNumber">{{indexData.good.count}}</div>
  104. </div>
  105. </el-col>
  106. </el-row>
  107. <el-row :gutter="32">
  108. <el-col :xs="24" :sm="24" :lg="6">
  109. <div class="topWindowBox">
  110. <div class="twbTitle">
  111. <div class="twbIconbg bg5">
  112. <img src="@/assets/index/topIcon5.png" />
  113. </div>
  114. 书刊音像发布总数量
  115. </div>
  116. <div class="twbNumber">{{indexData.book.count}}</div>
  117. </div>
  118. </el-col>
  119. <el-col :xs="24" :sm="24" :lg="6">
  120. <div class="topWindowBox">
  121. <div class="twbTitle">
  122. <div class="twbIconbg bg6">
  123. <img src="@/assets/index/topIcon6.png" />
  124. </div>
  125. 招聘发布总数量
  126. </div>
  127. <div class="twbNumber">{{indexData.jobRecruiting.count}}</div>
  128. </div>
  129. </el-col>
  130. <el-col :xs="24" :sm="24" :lg="6">
  131. <div class="topWindowBox">
  132. <div class="twbTitle">
  133. <div class="twbIconbg bg7">
  134. <img src="@/assets/index/topIcon7.png" />
  135. </div>
  136. 求职发布总数量
  137. </div>
  138. <div class="twbNumber">{{indexData.jobHunting.count}}</div>
  139. </div>
  140. </el-col>
  141. </el-row>
  142. <el-row :gutter="32">
  143. <el-col :xs="24" :sm="24" :lg="16">
  144. <div class="chartBox">
  145. <div class="chartTitle">
  146. 平台数据增长趋势
  147. <el-select
  148. v-model="chatType"
  149. placeholder="请选择"
  150. class="chartSelectInput"
  151. @change="changeLineChartData"
  152. >
  153. <el-option
  154. v-for="item in indexDataOptions"
  155. :key="item.value"
  156. :label="item.label"
  157. :value="item.value"
  158. >
  159. </el-option>
  160. </el-select>
  161. </div>
  162. <el-row style="background:#fff;padding:16px 16px 0;">
  163. <line-chart :chart-data="chartData.lineChartData" />
  164. </el-row>
  165. </div>
  166. </el-col>
  167. <el-col :xs="24" :sm="24" :lg="8">
  168. <div class="chartBox">
  169. <div class="chartTitle">用户类型占比</div>
  170. <div class="chart-wrapper">
  171. <ring-chart :chart-data="chartData.ringChartData" />
  172. </div>
  173. </div>
  174. </el-col>
  175. </el-row>
  176. </div>
  177. <!--超级管理员10000× 个人会员1√ 政务会员2× 企业会员3 调研员4-->
  178. <div v-if="userType == 1">
  179. <el-row :gutter="32">
  180. <el-col :xs="24" :sm="24" :lg="24">
  181. <div class="topDataBox">
  182. <div class="topDataBoxTitle">
  183. <div class="chatIconBox cibStyle1">
  184. <img src="@/assets/index/top_time.png">
  185. </div>
  186. <div class="topDataBoxTitleText">待审核列表</div>
  187. </div>
  188. <div class="topDataBoxList" v-if="indexData.apply">
  189. <div class="topDataLi1">
  190. <div class="topDataMain">
  191. <span @click="goToList(1)">待审核资讯</span>
  192. <span @click="goToList(1)">{{indexData.apply.article}}</span>
  193. </div>
  194. </div>
  195. <div class="topDataLi2">
  196. <div class="topDataMainCenter">
  197. <span @click="goToList(2)">待审核商品</span>
  198. <span @click="goToList(2)">{{indexData.apply.good}}</span>
  199. </div>
  200. <div class="topDataMainCenter">
  201. <span @click="goToList(3)">待审核书刊音像</span>
  202. <span @click="goToList(3)">{{indexData.apply.book}}</span>
  203. </div>
  204. </div>
  205. <div class="topDataLi3">
  206. <div class="topDataMainCenter">
  207. <span @click="goToList(4)">待审核招聘</span>
  208. <span @click="goToList(4)">{{indexData.apply.jobRecruiting}}</span>
  209. </div>
  210. <div class="topDataMainCenter">
  211. <span @click="goToList(5)">待审核求职</span>
  212. <span @click="goToList(5)">{{indexData.apply.jobHunting}}</span>
  213. </div>
  214. </div>
  215. <div class="topDataLi4">
  216. <div class="topDataMain">
  217. <span @click="goToList(6)">待审核行政通知</span>
  218. <span @click="goToList(6)">{{indexData.apply.notice}}</span>
  219. </div>
  220. <div class="topDataMain">
  221. <span @click="goToList(7)">待审核行政投诉</span>
  222. <span @click="goToList(7)">{{indexData.apply.complaint}}</span>
  223. </div>
  224. </div>
  225. </div>
  226. </div>
  227. </el-col>
  228. </el-row>
  229. <el-row :gutter="32">
  230. <el-col :xs="24" :sm="24" :lg="6">
  231. <div class="topWindowBox">
  232. <div class="twbTitle">
  233. <div class="twbIconbg bg3">
  234. <img src="@/assets/index/topIcon3.png" />
  235. </div>
  236. 资讯发布数量
  237. </div>
  238. <div class="twbNumber">{{indexData.article.count}}</div>
  239. </div>
  240. </el-col>
  241. <el-col :xs="24" :sm="24" :lg="6">
  242. <div class="topWindowBox">
  243. <div class="twbTitle">
  244. <div class="twbIconbg bg4">
  245. <img src="@/assets/index/topIcon4.png" />
  246. </div>
  247. 商品发布数量
  248. </div>
  249. <div class="twbNumber">{{indexData.good.count}}</div>
  250. </div>
  251. </el-col>
  252. <el-col :xs="24" :sm="24" :lg="6">
  253. <div class="topWindowBox">
  254. <div class="twbTitle">
  255. <div class="twbIconbg bg5">
  256. <img src="@/assets/index/topIcon5.png" />
  257. </div>
  258. 书刊音像发布数量
  259. </div>
  260. <div class="twbNumber">{{indexData.book.count}}</div>
  261. </div>
  262. </el-col>
  263. <el-col :xs="24" :sm="24" :lg="6">
  264. <div class="topWindowBox">
  265. <div class="twbTitle">
  266. <div class="twbIconbg bg7">
  267. <img src="@/assets/index/topIcon7.png" />
  268. </div>
  269. 求职发布数量
  270. </div>
  271. <div class="twbNumber">{{indexData.jobHunting.count}}</div>
  272. </div>
  273. </el-col>
  274. </el-row>
  275. </div>
  276. <!--超级管理员10000× 个人会员1× 政务会员2 √ 企业会员3× 调研员4×-->
  277. <div v-if="userType == 2">
  278. <el-row :gutter="32">
  279. <el-col :xs="24" :sm="24" :lg="24">
  280. <div class="topDataBox">
  281. <div class="topDataBoxTitle">
  282. <div class="chatIconBox cibStyle1">
  283. <img src="@/assets/index/top_time.png">
  284. </div>
  285. <div class="topDataBoxTitleText">待审核列表</div>
  286. </div>
  287. <div class="topDataBoxList" v-if="indexData.apply">
  288. <div class="topDataLi1">
  289. <div class="topDataMain">
  290. <span @click="goToList(1)">待审核资讯</span>
  291. <span @click="goToList(1)">{{indexData.apply.article}}</span>
  292. </div>
  293. </div>
  294. <div class="topDataLi2">
  295. <div class="topDataMainCenter">
  296. <span @click="goToList(2)">待审核商品</span>
  297. <span @click="goToList(2)">{{indexData.apply.good}}</span>
  298. </div>
  299. <div class="topDataMainCenter">
  300. <span @click="goToList(3)">待审核书刊音像</span>
  301. <span @click="goToList(3)">{{indexData.apply.book}}</span>
  302. </div>
  303. </div>
  304. <div class="topDataLi4">
  305. <div class="topDataMain">
  306. <span @click="goToList(6)">待审核行政通知</span>
  307. <span @click="goToList(6)">{{indexData.apply.notice}}</span>
  308. </div>
  309. <div class="topDataMain">
  310. <span @click="goToList(7)">待审核行政投诉</span>
  311. <span @click="goToList(7)">{{indexData.apply.complaint}}</span>
  312. </div>
  313. </div>
  314. </div>
  315. </div>
  316. </el-col>
  317. </el-row>
  318. <el-row :gutter="32">
  319. <el-col :xs="24" :sm="24" :lg="6">
  320. <div class="topWindowBox">
  321. <div class="twbTitle">
  322. <div class="twbIconbg bg3">
  323. <img src="@/assets/index/topIcon3.png" />
  324. </div>
  325. 资讯发布数量
  326. </div>
  327. <div class="twbNumber">{{indexData.article.count}}</div>
  328. </div>
  329. </el-col>
  330. <el-col :xs="24" :sm="24" :lg="6">
  331. <div class="topWindowBox">
  332. <div class="twbTitle">
  333. <div class="twbIconbg bg4">
  334. <img src="@/assets/index/topIcon4.png" />
  335. </div>
  336. 商品发布数量
  337. </div>
  338. <div class="twbNumber">{{indexData.good.count}}</div>
  339. </div>
  340. </el-col>
  341. <el-col :xs="24" :sm="24" :lg="6">
  342. <div class="topWindowBox">
  343. <div class="twbTitle">
  344. <div class="twbIconbg bg5">
  345. <img src="@/assets/index/topIcon5.png" />
  346. </div>
  347. 书刊音像发布数量
  348. </div>
  349. <div class="twbNumber">{{indexData.book.count}}</div>
  350. </div>
  351. </el-col>
  352. <el-col :xs="24" :sm="24" :lg="6">
  353. <div class="topWindowBox">
  354. <div class="twbTitle">
  355. <div class="twbIconbg bg8">
  356. <img src="@/assets/index/topIcon8.png" />
  357. </div>
  358. 待处理
  359. </div>
  360. <div class="twbNumber2">
  361. <div class="twbNumber2Item">
  362. <div class="twbNumber2ItemNum">{{indexData.notice.count}}</div>
  363. <div>行政通知</div>
  364. </div>
  365. <div class="twbNumber2Item">
  366. <div class="twbNumber2ItemNum">{{indexData.complaint.count}}</div>
  367. <div>行政投诉</div>
  368. </div>
  369. </div>
  370. </div>
  371. </el-col>
  372. </el-row>
  373. <!-- <div class="chartBox">
  374. <div class="chartTitle">已审核文章</div>
  375. <div class="chart-wrapper">
  376. 展示文章列表
  377. <el-table :data="type_id1.article" style="width: 100%" @row-click="handleClick">
  378. <el-table-column prop="title" label="标题" width="">
  379. </el-table-column>
  380. <el-table-column prop="created_at" label="创建时间" width="180">
  381. </el-table-column>
  382. <el-table-column prop="updated_at" label="创建时间" width="180">
  383. </el-table-column>
  384. <el-table-column prop="status" label="状态" width="180">
  385. <template slot-scope="scope">
  386. <el-tag :type="scope.row.status == 1 ? 'success' : 'danger'">{{ scope.row.status == 1 ? '已审核' :
  387. '未审核' }}</el-tag>
  388. </template>
  389. </el-table-column>
  390. </el-table>
  391. </div>
  392. </div> -->
  393. </div>
  394. <!--超级管理员10000× 个人会员1× 政务会员2× 企业会员3√ 调研员4×-->
  395. <div v-if="userType == 3">
  396. <el-row :gutter="32">
  397. <el-col :xs="24" :sm="24" :lg="24">
  398. <div class="topDataBox">
  399. <div class="topDataBoxTitle">
  400. <div class="chatIconBox cibStyle1">
  401. <img src="@/assets/index/top_time.png">
  402. </div>
  403. <div class="topDataBoxTitleText">待审核列表</div>
  404. </div>
  405. <div class="topDataBoxList" v-if="indexData.apply">
  406. <div class="topDataLi1">
  407. <div class="topDataMain">
  408. <span @click="goToList(1)">待审核资讯</span>
  409. <span @click="goToList(1)">{{indexData.apply.article}}</span>
  410. </div>
  411. </div>
  412. <div class="topDataLi2">
  413. <div class="topDataMainCenter">
  414. <span @click="goToList(2)">待审核商品</span>
  415. <span @click="goToList(2)">{{indexData.apply.good}}</span>
  416. </div>
  417. <div class="topDataMainCenter">
  418. <span @click="goToList(3)">待审核书刊音像</span>
  419. <span @click="goToList(3)">{{indexData.apply.book}}</span>
  420. </div>
  421. </div>
  422. <div class="topDataLi3">
  423. <div class="topDataMainCenter">
  424. <span @click="goToList(4)">待审核招聘</span>
  425. <span @click="goToList(4)">{{indexData.apply.jobRecruiting}}</span>
  426. </div>
  427. </div>
  428. <div class="topDataLi4">
  429. <div class="topDataMain">
  430. <span @click="goToList(6)">待审核行政通知</span>
  431. <span @click="goToList(6)">{{indexData.apply.notice}}</span>
  432. </div>
  433. <div class="topDataMain">
  434. <span @click="goToList(7)">待审核行政投诉</span>
  435. <span @click="goToList(7)">{{indexData.apply.complaint}}</span>
  436. </div>
  437. </div>
  438. </div>
  439. </div>
  440. </el-col>
  441. </el-row>
  442. <el-row :gutter="32">
  443. <el-col :xs="24" :sm="24" :lg="6">
  444. <div class="topWindowBox">
  445. <div class="twbTitle">
  446. <div class="twbIconbg bg3">
  447. <img src="@/assets/index/topIcon3.png" />
  448. </div>
  449. 资讯发布数量
  450. </div>
  451. <div class="twbNumber">{{indexData.article.count}}</div>
  452. </div>
  453. </el-col>
  454. <el-col :xs="24" :sm="24" :lg="6">
  455. <div class="topWindowBox">
  456. <div class="twbTitle">
  457. <div class="twbIconbg bg4">
  458. <img src="@/assets/index/topIcon4.png" />
  459. </div>
  460. 商品发布数量
  461. </div>
  462. <div class="twbNumber">{{indexData.good.count}}</div>
  463. </div>
  464. </el-col>
  465. <el-col :xs="24" :sm="24" :lg="6">
  466. <div class="topWindowBox">
  467. <div class="twbTitle">
  468. <div class="twbIconbg bg5">
  469. <img src="@/assets/index/topIcon5.png" />
  470. </div>
  471. 书刊音像发布数量
  472. </div>
  473. <div class="twbNumber">{{indexData.book.count}}</div>
  474. </div>
  475. </el-col>
  476. <el-col :xs="24" :sm="24" :lg="6">
  477. <div class="topWindowBox">
  478. <div class="twbTitle">
  479. <div class="twbIconbg bg6">
  480. <img src="@/assets/index/topIcon6.png" />
  481. </div>
  482. 招聘发布数量
  483. </div>
  484. <div class="twbNumber">{{indexData.jobRecruiting.count}}</div>
  485. </div>
  486. </el-col>
  487. </el-row>
  488. </div>
  489. <!--超级管理员10000× 个人会员1× 政务会员2× 企业会员3× 调研员4√-->
  490. <div v-if="userType == 4">
  491. <el-row :gutter="32">
  492. <el-col :xs="24" :sm="24" :lg="24">
  493. <div class="topDataBox">
  494. <div class="topDataBoxTitle">
  495. <div class="chatIconBox cibStyle1">
  496. <img src="@/assets/index/top_time.png">
  497. </div>
  498. <div class="topDataBoxTitleText">待审核列表</div>
  499. </div>
  500. <div class="topDataBoxList" v-if="indexData.apply">
  501. <div class="topDataLi1">
  502. <div class="topDataMain">
  503. <span @click="goToList(1)">待审核资讯</span>
  504. <span @click="goToList(1)">{{indexData.apply.article}}</span>
  505. </div>
  506. </div>
  507. <div class="topDataLi2">
  508. <div class="topDataMainCenter">
  509. <span @click="goToList(2)">待审核商品</span>
  510. <span @click="goToList(2)">{{indexData.apply.good}}</span>
  511. </div>
  512. <div class="topDataMainCenter">
  513. <span @click="goToList(3)">待审核书刊音像</span>
  514. <span @click="goToList(3)">{{indexData.apply.book}}</span>
  515. </div>
  516. </div>
  517. <div class="topDataLi4">
  518. <div class="topDataMain">
  519. <span @click="goToList(6)">待审核行政通知</span>
  520. <span @click="goToList(6)">{{indexData.apply.notice}}</span>
  521. </div>
  522. <div class="topDataMain">
  523. <span @click="goToList(7)">待审核行政投诉</span>
  524. <span @click="goToList(7)">{{indexData.apply.complaint}}</span>
  525. </div>
  526. </div>
  527. </div>
  528. </div>
  529. </el-col>
  530. </el-row>
  531. <el-row :gutter="32">
  532. <el-col :xs="24" :sm="24" :lg="8">
  533. <div class="topWindowBox">
  534. <div class="twbTitle">
  535. <div class="twbIconbg bg3">
  536. <img src="@/assets/index/topIcon3.png" />
  537. </div>
  538. 资讯发布数量
  539. </div>
  540. <div class="twbNumber">{{indexData.article.count}}</div>
  541. </div>
  542. </el-col>
  543. <el-col :xs="24" :sm="24" :lg="8">
  544. <div class="topWindowBox">
  545. <div class="twbTitle">
  546. <div class="twbIconbg bg4">
  547. <img src="@/assets/index/topIcon4.png" />
  548. </div>
  549. 商品发布数量
  550. </div>
  551. <div class="twbNumber">{{indexData.good.count}}</div>
  552. </div>
  553. </el-col>
  554. <el-col :xs="24" :sm="24" :lg="8">
  555. <div class="topWindowBox">
  556. <div class="twbTitle">
  557. <div class="twbIconbg bg5">
  558. <img src="@/assets/index/topIcon5.png" />
  559. </div>
  560. 书刊音像发布数量
  561. </div>
  562. <div class="twbNumber">{{indexData.book.count}}</div>
  563. </div>
  564. </el-col>
  565. </el-row>
  566. </div>
  567. </div>
  568. </template>
  569. <script>
  570. // import GithubCorner from '@/components/GithubCorner'
  571. // import PanelGroup from './components/PanelGroup'
  572. import LineChart from './components/LineChart'//折线图
  573. // import RaddarChart from './components/RaddarChart'
  574. // import PieChart from './components/PieChart'
  575. // import BarChart from './components/BarChart'
  576. // import TransactionTable from './components/TransactionTable'
  577. // import TodoList from './components/TodoList'
  578. // import BoxCard from './components/BoxCard'
  579. import RingChart from './components/RingChart'//圆环图
  580. export default {
  581. name: 'DashboardAdmin',
  582. components: {
  583. // GithubCorner,
  584. // PanelGroup,
  585. LineChart,
  586. // RaddarChart,
  587. // PieChart,
  588. // BarChart,
  589. // TransactionTable,
  590. // TodoList,
  591. // BoxCard,
  592. RingChart
  593. },
  594. data() {
  595. return {
  596. userType: 0,//用户身份
  597. indexData:[],//首页的全部数据
  598. chartData: {
  599. lineChartData:[],//折线图目前展示哪个数据
  600. ringChartData: [],//圆环图数据
  601. lineChartData1: [],//折线图数据 - 资讯
  602. lineChartData2: [],//折线图数据 - 商品
  603. lineChartData3: [],//折线图数据 - 书刊音像
  604. lineChartData4: [],//折线图数据 - 招聘
  605. lineChartData5: [],//折线图数据 - 求职
  606. },
  607. chatType: '1', //用户选择的哪个数据
  608. indexDataOptions: [
  609. {label:'资讯',value:'1'},
  610. {label:'商品',value:'2'},
  611. {label:'书刊音像',value:'3'},
  612. {label:'招聘',value:'4'},
  613. {label:'求职',value:'5'}
  614. ]
  615. }
  616. },
  617. methods: {
  618. handleClick(row) {
  619. console.log(row, '----------------1---')
  620. //跳转
  621. this.$router.push({
  622. path: '/articleList',
  623. query: {
  624. id: row.id
  625. }
  626. })
  627. },
  628. // 获取首页数据
  629. //获取用户身份信息
  630. getUserInfo(fun) {
  631. this.$store.dispatch('public/getInfo').then(res => {
  632. console.log(res)
  633. this.userType = res.data.type_id;
  634. //if(res.data.type_id==10000){}//管理员
  635. //if(res.data.type_id==4){}//调研员
  636. //个人会员=1 政务会员=2 企业会员=3 调研员=4 管理员=10000 游客=20000
  637. }).catch(() => {
  638. this.$message({
  639. type: 'info',
  640. message: '网络错误,请重试!'
  641. });
  642. })
  643. fun();
  644. },
  645. getData() {
  646. //获取首页数据
  647. this.$store.dispatch('public/getAdminIndex').then(res => {
  648. //如果是调研员就不显示其他的
  649. // if (this.userType == 4) {
  650. // this.chartData.lineChartData = res.data.letterOfComplaintList;
  651. // } else if (this.userType == 1) {
  652. // //个人会员
  653. // this.type_id1 = res.data;
  654. // } else {
  655. // this.topData.article.count = res.data.article.count;
  656. // this.topData.category.count = res.data.category.count;
  657. // this.topData.website.count = res.data.website.count;
  658. // this.chartData.lineChartData = res.data.monthArticle;
  659. // this.chartData.ringChartData = res.data.userType;
  660. // }
  661. if(res.code==200){
  662. this.indexData = res.data;//面板其他数据
  663. this.chartData.lineChartData = res.data.monthArticle;//初始化展示资讯的数据
  664. this.chartData.ringChartData = res.data.userType;//圆环图数据
  665. this.chartData.lineChartData1 = res.data.monthArticle;//折线图数据 - 资讯
  666. this.chartData.lineChartData2 = res.data.monthGood;//圆环图数据 - 资讯
  667. this.chartData.lineChartData3 = res.data.monthBook;//圆环图数据 - 书刊音像
  668. this.chartData.lineChartData4 = res.data.monthJobRecruiting;//圆环图数据 - 招聘
  669. this.chartData.lineChartData5 = res.data.monthJobHunting;//圆环图数据 - 求职
  670. }
  671. })
  672. },
  673. goToList(typenumber){
  674. if(typenumber == 1){this.$router.push({path:'/examine'})}
  675. if(typenumber == 2){this.$router.push({path:'/goodListApply'})}
  676. if(typenumber == 3){this.$router.push({path:'/bookListApply'})}
  677. if(typenumber == 4){this.$router.push({path:'/checkjobRecruitingList'})}
  678. if(typenumber == 5){this.$router.push({path:'/jobHuntingListApply'})}
  679. if(typenumber == 6){this.$router.push({path:'/noticeListApply'})}
  680. if(typenumber == 7){this.$router.push({path:'/ncomplaintListApply'})}
  681. if(typenumber == 8){this.$router.push({path:'/adList'})}
  682. },
  683. //切换折线图数据
  684. changeLineChartData(type){
  685. console.log(type)
  686. if(type == 1){
  687. this.chartData.lineChartData = this.chartData.lineChartData1;
  688. }
  689. if(type == 2){
  690. this.chartData.lineChartData = this.chartData.lineChartData2;
  691. }
  692. if(type == 3){
  693. this.chartData.lineChartData = this.chartData.lineChartData3;
  694. }
  695. if(type == 4){
  696. this.chartData.lineChartData = this.chartData.lineChartData4;
  697. }
  698. if(type == 5){
  699. this.chartData.lineChartData = this.chartData.lineChartData5;
  700. }
  701. }
  702. },
  703. mounted() {
  704. //先获取用户身份
  705. this.getUserInfo(this.getData)
  706. //再获取数据
  707. // this.getData()
  708. }
  709. }
  710. </script>
  711. <style lang="less" scoped>
  712. @title: #212227;
  713. @bgColor: #FFFFFF;
  714. //图标背景
  715. .chatIconBox {
  716. width: 40px;
  717. height: 40px;
  718. border-radius: 50%;
  719. line-height: 40px;
  720. overflow: hidden;
  721. display: flex;
  722. align-items: center;
  723. justify-content: center;
  724. }
  725. .cibStyle1 {
  726. background:#667EF2
  727. }
  728. //管理员顶部数据栏
  729. .topDataBox {
  730. height: 182px;
  731. background: url('../../../assets/index/top_bg.png') no-repeat center center;
  732. background-size: 100% 100%;
  733. margin-bottom: 30px;
  734. border-radius: 20px;
  735. overflow: hidden;
  736. box-sizing: border-box;
  737. padding: 25px;
  738. }
  739. .topDataBoxTitle {
  740. display: flex;
  741. align-items: center;
  742. margin-bottom:16px;
  743. color:#fff;
  744. font-size:16px;
  745. }
  746. .topDataBoxTitleText {
  747. margin-left: 15px;
  748. }
  749. //顶部数据展示
  750. .topDataBoxList {
  751. display: flex;
  752. align-items: center;
  753. .topDataLi1 {
  754. width:268px;
  755. border-right: 1px solid #fff;
  756. height:70px;
  757. .topDataMain:nth-child(1) {
  758. margin-bottom:20px;
  759. }
  760. }
  761. .topDataLi2,.topDataLi3{
  762. width:359px;
  763. border-right: 1px solid #fff;
  764. height:70px;
  765. .topDataMainCenter:nth-child(1){
  766. margin-bottom:20px
  767. }
  768. }
  769. .topDataLi4 {
  770. width:268px;
  771. height:70px;
  772. .topDataMain {
  773. margin-left:90px;
  774. }
  775. .topDataMain:nth-child(1) {
  776. margin-bottom:20px;
  777. }
  778. }
  779. .topDataMain,.topDataMainCenter {
  780. color:#fff;
  781. height:26px;
  782. line-height:26px;
  783. width:177px;
  784. display:flex;
  785. align-items: center;
  786. justify-content: space-between;
  787. span:nth-child(1){
  788. font-size:16px;
  789. cursor: pointer;
  790. }
  791. span:nth-child(2){
  792. font-size:22px;
  793. font-weight:bold;
  794. cursor: pointer;
  795. }
  796. }
  797. .topDataMainCenter {
  798. margin:0 auto;
  799. }
  800. }
  801. .topWindowBox {
  802. background: @bgColor;
  803. border-Radius: 20px;
  804. height: 165px;
  805. width: 100%;
  806. margin-bottom: 30px;
  807. padding: 22px 25px 25px 25px;
  808. box-sizing: border-box;
  809. .twbTitle {
  810. display: flex;
  811. align-items: center;
  812. font-size: 16px;
  813. color: @title;
  814. .twbIconbg{
  815. width: 40px;
  816. height: 40px;
  817. border-radius: 50%;
  818. margin-right: 15px;
  819. display:flex;
  820. align-items: center;
  821. justify-content: center;
  822. }
  823. .bg1 {background: #FDF2F9;}
  824. .bg2 {background: #E9F3FC;}
  825. .bg3 {background: #F7F2FD;}
  826. .bg4 {background: #FFF4F4;}
  827. .bg5 {background: #E9F3FC;}
  828. .bg6 {background: #F2EBFC;}
  829. .bg7 {background: #FDF2F9;}
  830. .bg8 {background: #FFFAF4;}
  831. }
  832. .twbNumber {
  833. font-size: 30px;
  834. margin-top: 20px;
  835. font-weight: 1000;
  836. }
  837. .twbNumber2 {
  838. font-size: 30px;
  839. margin-top: 20px;
  840. font-weight: 1000;
  841. display: flex;
  842. align-items: center;
  843. justify-content: flex-start;
  844. .twbNumber2ItemNum {
  845. font-size:30px;
  846. margin-bottom:5px;
  847. font-weight:1000;
  848. }
  849. .twbNumber2Item {
  850. font-size:16px;
  851. width:70px;
  852. font-weight:normal;
  853. }
  854. .twbNumber2Item:nth-child(1) {
  855. margin-right:130px;
  856. }
  857. }
  858. .twbStatus,
  859. .twbStatusDown {
  860. font-size: 14px;
  861. margin-top: 10px;
  862. display: flex;
  863. img {
  864. display: block;
  865. margin-right: 4px;
  866. }
  867. span {
  868. color: #707B81;
  869. margin-left: 8px;
  870. }
  871. }
  872. .twbStatus {
  873. color: #23C581;
  874. }
  875. .twbStatusDown {
  876. color: #E74545
  877. }
  878. }
  879. .chartBox {
  880. width: 100%;
  881. height: 440px;
  882. border-radius: 20px;
  883. overflow: hidden;
  884. background-color: @bgColor;
  885. .chartTitle {
  886. color: @title;
  887. padding: 30px 30px 0 30px;
  888. font-size: 24px;
  889. }
  890. }
  891. .noData {
  892. color: #CCCCCC;
  893. font-size: 32px;
  894. font-weight: bold;
  895. text-align: center;
  896. height: 740px;
  897. line-height: 740px;
  898. }
  899. .dashboard-editor-container {
  900. padding: 32px;
  901. background-color: rgb(240, 242, 245);
  902. position: relative;
  903. .github-corner {
  904. position: absolute;
  905. top: 0px;
  906. border: 0;
  907. right: 0;
  908. }
  909. .chart-wrapper {
  910. background: #fff;
  911. padding: 16px 16px 0;
  912. margin-bottom: 32px;
  913. }
  914. }
  915. @media (max-width:1024px) {
  916. .chart-wrapper {
  917. padding: 8px;
  918. }
  919. }
  920. ::v-deep .chartSelectInput .el-input__inner {
  921. background:#F2F4FE;
  922. color:#5570F1;
  923. border:none;
  924. border-radius: 8px;
  925. width:130px;
  926. margin-left:20px;
  927. }
  928. </style>