mirror of
https://github.com/empayre/fleet.git
synced 2024-11-07 09:18:59 +00:00
c27dd72f33
Add activity feed to homepage
71 lines
2.0 KiB
TypeScript
71 lines
2.0 KiB
TypeScript
import React from "react";
|
|
import { useSelector } from "react-redux";
|
|
|
|
import paths from "router/paths";
|
|
import { Link } from "react-router";
|
|
import { IUser } from "interfaces/user";
|
|
import HostsSummary from "./HostsSummary";
|
|
import ActivityFeed from "./ActivityFeed";
|
|
|
|
import LinkArrow from "../../../assets/images/icon-arrow-right-vibrant-blue-10x18@2x.png";
|
|
|
|
const baseClass = "homepage";
|
|
|
|
interface IRootState {
|
|
auth: {
|
|
user: IUser;
|
|
};
|
|
app: {
|
|
config: {
|
|
org_name: string;
|
|
};
|
|
};
|
|
}
|
|
|
|
const Homepage = (): JSX.Element => {
|
|
const { MANAGE_HOSTS } = paths;
|
|
|
|
const user = useSelector((state: IRootState) => state.auth.user);
|
|
const orgName = useSelector((state: IRootState) => state.app.config.org_name);
|
|
|
|
return (
|
|
<div className={baseClass}>
|
|
<div className={`${baseClass}__wrapper body-wrap`}>
|
|
<div className={`${baseClass}__header-wrap`}>
|
|
<div className={`${baseClass}__header`}>
|
|
<h1 className={`${baseClass}__title`}>
|
|
<span>{orgName}</span>
|
|
</h1>
|
|
</div>
|
|
</div>
|
|
<div className={`${baseClass}__section hosts-section`}>
|
|
<div className={`${baseClass}__section-title`}>
|
|
<div>
|
|
<h2>Hosts</h2>
|
|
</div>
|
|
<Link to={MANAGE_HOSTS} className={`${baseClass}__host-link`}>
|
|
<span>View all hosts</span>
|
|
<img src={LinkArrow} alt="link arrow" id="link-arrow" />
|
|
</Link>
|
|
</div>
|
|
<div className={`${baseClass}__section-details`}>
|
|
<HostsSummary />
|
|
</div>
|
|
</div>
|
|
<div className={`${baseClass}__section hosts-section`}>
|
|
<div className={`${baseClass}__section-title`}>
|
|
<div>
|
|
<h2>Activity</h2>
|
|
</div>
|
|
</div>
|
|
<div className={`${baseClass}__section-details`}>
|
|
<ActivityFeed />
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
);
|
|
};
|
|
|
|
export default Homepage;
|