| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273 |
- import React, { useEffect, useState } from 'react';
- import { useTranslation } from 'react-i18next';
- import { getFooterHTML, getSystemName } from '../helpers';
- import { Layout, Tooltip } from '@douyinfe/semi-ui';
- const FooterBar = () => {
- const { t } = useTranslation();
- const systemName = getSystemName();
- const [footer, setFooter] = useState(getFooterHTML());
- let remainCheckTimes = 5;
- const loadFooter = () => {
- let footer_html = localStorage.getItem('footer_html');
- if (footer_html) {
- setFooter(footer_html);
- }
- };
- const defaultFooter = (
- <div className='custom-footer'>
- <a
- href='https://github.com/Calcium-Ion/new-api'
- target='_blank'
- rel='noreferrer'
- >
- New API {import.meta.env.VITE_REACT_APP_VERSION}{' '}
- </a>
- {t('由')}{' '}
- <a
- href='https://github.com/Calcium-Ion'
- target='_blank'
- rel='noreferrer'
- >
- Calcium-Ion
- </a>{' '}
- {t('开发,基于')}{' '}
- <a
- href='https://github.com/songquanpeng/one-api'
- target='_blank'
- rel='noreferrer'
- >
- One API
- </a>
- </div>
- );
- useEffect(() => {
- const timer = setInterval(() => {
- if (remainCheckTimes <= 0) {
- clearInterval(timer);
- return;
- }
- remainCheckTimes--;
- loadFooter();
- }, 200);
- return () => clearTimeout(timer);
- }, []);
- return (
- <div style={{ textAlign: 'center' }}>
- {footer ? (
- <div
- className='custom-footer'
- dangerouslySetInnerHTML={{ __html: footer }}
- ></div>
- ) : (
- defaultFooter
- )}
- </div>
- );
- };
- export default FooterBar;
|