Commit 1b56a1f5 authored by 周宏民's avatar 周宏民

pref: 演示入口功能 loading优化

parent b122d3d9
Pipeline #86110 waiting for manual action with stages
...@@ -9,7 +9,7 @@ ...@@ -9,7 +9,7 @@
*/ */
import { FullscreenExitOutlined, FullscreenOutlined, RightOutlined } from '@ant-design/icons'; import { FullscreenExitOutlined, FullscreenOutlined, RightOutlined } from '@ant-design/icons';
import exitImg from '@/assets/images/demonstration/退出.png'; import exitImg from '@/assets/images/demonstration/退出.png';
import { Button, Spin, message, Tooltip } from 'antd'; import { Button, Spin, message, Progress } from 'antd';
import React, { useMemo, useState, useEffect, useRef } from 'react'; import React, { useMemo, useState, useEffect, useRef } from 'react';
import { cloneDeep, debounce } from 'lodash'; import { cloneDeep, debounce } from 'lodash';
import Cookies from 'js-cookie'; import Cookies from 'js-cookie';
...@@ -35,7 +35,12 @@ const Demonstration = props => { ...@@ -35,7 +35,12 @@ const Demonstration = props => {
const showFullScreen = true; const showFullScreen = true;
const videoRef = useRef(null); const videoRef = useRef(null);
const [loginAction, setAction] = useState(() => new LoginAction(props)); const [loginAction, setAction] = useState(() => new LoginAction(props));
const progressRef = useRef(0);
const timer = useRef(null);
const [progressValue, setProgressValue] = useState(0);
const [loading, setLoading] = useState(true); const [loading, setLoading] = useState(true);
const [showContent, setShowContent] = useState(false);
const [jumpLoading, setJumpLoading] = useState(false); const [jumpLoading, setJumpLoading] = useState(false);
const [selectKey, setSelectKey] = useState('供水产品'); const [selectKey, setSelectKey] = useState('供水产品');
const [boxSize, setBoxSize] = useState({ const [boxSize, setBoxSize] = useState({
...@@ -298,7 +303,28 @@ const Demonstration = props => { ...@@ -298,7 +303,28 @@ const Demonstration = props => {
const handError = err => { const handError = err => {
setJumpLoading(false); setJumpLoading(false);
}; };
useEffect(() => {
if (loading && !timer.current) {
timer.current = setInterval(() => {
if (progressRef.current < 80) {
progressRef.current += 20;
setProgressValue(progressRef.current);
} else {
setProgressValue(99);
timer.current && clearInterval(timer.current);
timer.current = null;
}
}, 100);
}
if (!loading) {
setProgressValue(100);
timer.current && clearInterval(timer.current);
timer.current = null;
setTimeout(() => {
setShowContent(true);
}, 0);
}
}, [loading]);
useEffect(() => { useEffect(() => {
const handleToggleIndustry = event => { const handleToggleIndustry = event => {
props.history && props.history.push(`/?client=${props.global.client}`); props.history && props.history.push(`/?client=${props.global.client}`);
...@@ -331,6 +357,17 @@ const Demonstration = props => { ...@@ -331,6 +357,17 @@ const Demonstration = props => {
<div className={styles.jumpLoader} /> <div className={styles.jumpLoader} />
</div> </div>
) : null} ) : null}
{loading || progressValue !== 100 ? (
<div className={styles.loadingWrap}>
<Progress
style={{ width: '30%' }}
trailColor="rgba(255,255,255,0.5)"
strokeColor="#1685FF"
percent={progressValue}
showInfo={false}
/>
</div>
) : null}
{showFullScreen ? ( {showFullScreen ? (
<div className={styles.CV_exit} onClick={exit}> <div className={styles.CV_exit} onClick={exit}>
<Button type="text" style={{ color: '#fff', fontSize: '24px' }}> <Button type="text" style={{ color: '#fff', fontSize: '24px' }}>
...@@ -359,12 +396,8 @@ const Demonstration = props => { ...@@ -359,12 +396,8 @@ const Demonstration = props => {
<div className={styles.top_r_text}>- 引领中国智慧水务 -</div> <div className={styles.top_r_text}>- 引领中国智慧水务 -</div>
</div> </div>
</div> </div>
{loading ? (
<div className={styles.loadingWrap}> {showContent ? (
<div className={styles.loader} />
</div>
) : null}
{!loading ? (
<> <>
<div className={classNames(styles.row, 'animate__fadeInDown', 'animate__animated', 'duration-500ms')}> <div className={classNames(styles.row, 'animate__fadeInDown', 'animate__animated', 'duration-500ms')}>
<div className={styles.row_l}> <div className={styles.row_l}>
......
...@@ -5,7 +5,7 @@ ...@@ -5,7 +5,7 @@
width: 100%; width: 100%;
overflow: hidden; overflow: hidden;
display: flex; display: flex;
background: url('@{imgSrc}/背景.png') no-repeat center center; background:rgba(8, 33, 77, 1) url('@{imgSrc}/背景.png') no-repeat center center;
background-size: 100% 100%; background-size: 100% 100%;
position: relative; position: relative;
font-size: 14px; font-size: 14px;
...@@ -375,3 +375,16 @@ ...@@ -375,3 +375,16 @@
height: 4px height: 4px
} }
} }
.loadingWrap {
width: 100%;
height: 100%;
position: absolute;
display: flex;
align-items: center;
justify-content: center;
bottom: 20%;
left: 50%;
z-index: 10;
transform: translateX(-50%);
}
\ No newline at end of file
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment