src/components/StatusBar.tsx
import { GithubOutlined, InfoCircleOutlined } from '@ant-design/icons';
import { Col, Layout, Row, Space, Typography } from 'antd';
import { useEffect, useState } from 'react';
import { connect } from 'react-redux';
import { Link } from 'react-router-dom';
import { Routes } from '../routes';
import { AppState, TuneState } from '../types/state';
const { Footer } = Layout;
const mapStateToProps = (state: AppState) => ({
status: state.status,
config: state.config,
tune: state.tune,
});
const Firmware = ({ tune }: { tune: TuneState }) => {
const [width, setWidth] = useState(1000);
const calculateWidth = () => {
setWidth(window.innerWidth - 130);
};
useEffect(() => {
calculateWidth();
window.addEventListener('resize', calculateWidth);
return () => {
window.removeEventListener('resize', calculateWidth);
};
}, []);
return (
<Space>
<InfoCircleOutlined />
<Typography.Text ellipsis style={{ maxWidth: width }}>
{[tune.details.signature, tune.details.writeDate, tune.details.author]
.filter(Boolean)
.join(' - ')}
</Typography.Text>
</Space>
);
};
const StatusBar = ({ tune }: { tune: TuneState | null }) => {
return (
<Footer className="app-status-bar">
<Row>
<Col span={20}>{tune && <Firmware tune={tune} />}</Col>
<Col span={4} style={{ textAlign: 'right' }}>
<Link to={Routes.ABOUT}>
<Space>
<GithubOutlined />
GitHub
</Space>
</Link>
</Col>
</Row>
</Footer>
);
};
export default connect(mapStateToProps)(StatusBar);