|
@@ -1,10 +1,24 @@
|
1
|
|
-import React from 'react'
|
2
|
|
-import { Image, Statistic, Row, Col, Badge, Divider } from 'antd'
|
|
1
|
+import React, { useState, useEffect } from 'react'
|
|
2
|
+import { Image, Statistic, Spin, Badge } from 'antd'
|
3
|
3
|
import { connect } from 'umi'
|
|
4
|
+import request from '@/utils/request'
|
4
|
5
|
import { defaultAvatar } from '@/utils/utils';
|
5
|
6
|
import Styles from '../style.less'
|
6
|
7
|
|
7
|
8
|
const HeaderContent = (props) => {
|
|
9
|
+ const [loading, setLoading] = useState(false)
|
|
10
|
+ const [statis, setStatis] = useState({})
|
|
11
|
+
|
|
12
|
+ useEffect(() => {
|
|
13
|
+ setLoading(true)
|
|
14
|
+ request('/index/post-data').then((res) => {
|
|
15
|
+ setStatis(res)
|
|
16
|
+ setLoading(false)
|
|
17
|
+ }).catch((e) => {
|
|
18
|
+ setLoading(false)
|
|
19
|
+ })
|
|
20
|
+ }, [])
|
|
21
|
+
|
8
|
22
|
return (
|
9
|
23
|
<div className={Styles['header-content']}>
|
10
|
24
|
<div className={Styles['ctt-header']}>
|
|
@@ -18,11 +32,13 @@ const HeaderContent = (props) => {
|
18
|
32
|
</p>
|
19
|
33
|
</div>
|
20
|
34
|
<div className={Styles['ctt-footer']}>
|
21
|
|
- <div className={Styles['st-wrapper']}>
|
22
|
|
- <div className={Styles['st-item']}><Statistic title="科普数量" value={112893} /></div>
|
23
|
|
- <div className={Styles['st-item']}><Statistic title="浏览总数" value={112893} /></div>
|
24
|
|
- <div className={Styles['st-item']}><Statistic title="学生总数" value={112893} /></div>
|
25
|
|
- </div>
|
|
35
|
+ <Spin spinning={loading}>
|
|
36
|
+ <div className={Styles['st-wrapper']}>
|
|
37
|
+ <div className={Styles['st-item']}><Statistic title="科普数量" value={statis.total} /></div>
|
|
38
|
+ <div className={Styles['st-item']}><Statistic title="浏览总数" value={statis.pv} /></div>
|
|
39
|
+ <div className={Styles['st-item']}><Statistic title="学生总数" value={statis.student} /></div>
|
|
40
|
+ </div>
|
|
41
|
+ </Spin>
|
26
|
42
|
</div>
|
27
|
43
|
</div>
|
28
|
44
|
)
|