import React, { useEffect, useState, useRef } from 'react'; import { Statistic, Modal, Tag, Button, Spin, message } from 'antd'; import { request } from '@/utils/http'; import config from '@/utils/config'; import { version } from '../../version'; const { Countdown } = Statistic; const CheckUpdate = ({ socketMessage }: any) => { const [updateLoading, setUpdateLoading] = useState(false); const [value, setValue] = useState(''); const modalRef = useRef(); const checkUpgrade = () => { if (updateLoading) return; setUpdateLoading(true); message.loading('检查更新中...', 0); request .put(`${config.apiPrefix}system/update-check`) .then((_data: any) => { message.destroy(); const { code, data } = _data; if (code === 200) { if (data.hasNewVersion) { showConfirmUpdateModal(data); } else { showForceUpdateModal(); } } else { message.error(data); } }) .catch((error: any) => { message.destroy(); console.log(error); }) .finally(() => { setUpdateLoading(false); }); }; const showForceUpdateModal = () => { Modal.confirm({ width: 500, title: '更新', content: ( <>
已经是最新版了!
青龙 {version} 是目前检测到的最新可用版本了。
), okText: '确认', cancelText: '强制更新', onCancel() { showUpdatingModal(); request .put(`${config.apiPrefix}system/update`) .then((_data: any) => {}) .catch((error: any) => { console.log(error); }); }, }); }; const showConfirmUpdateModal = (data: any) => { const { lastVersion, lastLog } = data; Modal.confirm({ width: 500, title: ( <>
更新可用
新版本{lastVersion}可用。你使用的版本为{version}。
), content: (
          {lastLog}
        
), okText: '更新', cancelText: '以后再说', onOk() { showUpdatingModal(); request .put(`${config.apiPrefix}system/update`) .then((_data: any) => {}) .catch((error: any) => { console.log(error); }); }, }); }; const showUpdatingModal = () => { modalRef.current = Modal.info({ width: 600, maskClosable: false, closable: false, okButtonProps: { disabled: true }, title: '更新日志', centered: true, content: (
            {value}
          
), }); }; useEffect(() => { if (!modalRef.current || !socketMessage) { return; } const { type, message: _message, references } = socketMessage; if (type !== 'updateSystemVersion') { return; } const newMessage = `${value}${_message}`; modalRef.current.update({ content: (
            {newMessage}
          
), }); setValue(newMessage); document.getElementById('log-identifier') && document .getElementById('log-identifier')! .scrollIntoView({ behavior: 'smooth', block: 'nearest' }); if (_message.includes('重启面板')) { message.warning({ content: ( 系统将在 秒后自动刷新 ), duration: 30, }); setTimeout(() => { window.location.reload(); }, 30000); } }, [socketMessage]); return ( <> ); }; export default CheckUpdate;