dashboard/src/components/app.tsx

79 lines
1.6 KiB
TypeScript
Raw Normal View History

2020-07-08 19:36:36 +02:00
import Icon from "./icon";
import styled from "styled-components";
2021-03-21 18:05:24 +01:00
import selectedTheme from "../lib/theme";
2020-07-08 19:36:36 +02:00
2021-04-23 23:59:14 +02:00
const AppContainer = styled.a`
2020-07-08 19:36:36 +02:00
display: flex;
2021-04-23 23:59:14 +02:00
flex: 1 0 auto;
2020-07-08 19:36:36 +02:00
padding: 1rem;
2021-04-23 23:59:14 +02:00
color: ${selectedTheme.mainColor};
font-weight: 500;
text-transform: uppercase;
margin: 0;
text-decoration: none;
font-size: 1rem;
2020-07-08 19:36:36 +02:00
`;
const IconContainer = styled.div`
2020-07-09 16:22:18 +02:00
display: flex;
justify-content: center;
align-items: center;
2020-07-08 19:36:36 +02:00
margin-right: 0.5rem;
`;
const DetailsContainer = styled.div`
display: flex;
flex-direction: column;
`;
2021-04-23 23:59:14 +02:00
const AppName = styled.div`
2021-06-30 00:56:01 +02:00
a:hover {
2020-07-08 19:36:36 +02:00
text-decoration: underline;
}
`;
const AppDescription = styled.p`
text-transform: uppercase;
margin: 0;
font-size: 0.65rem;
font-weight: 400;
color: ${selectedTheme.accentColor};
`;
export interface IAppProps {
name: string;
icon: string;
2021-03-21 19:59:18 +01:00
url: string;
2020-07-08 19:36:36 +02:00
displayURL: string;
2021-04-03 16:54:44 +02:00
newTab?: boolean;
2020-07-08 19:36:36 +02:00
}
2021-03-21 18:05:24 +01:00
/**
2021-03-21 19:59:18 +01:00
* Renders a single app shortcut
2021-06-14 11:29:03 +02:00
* @param {IAppProps} props the props of the given app
* @returns {React.ReactNode} the child node for the given app
2021-03-21 18:05:24 +01:00
*/
2021-06-14 11:29:03 +02:00
const App = ({ name, icon, url, displayURL, newTab }: IAppProps) => {
const linkAttrs =
newTab !== undefined && newTab
? {
target: "_blank",
rel: "noopener noreferrer",
}
: {};
2021-04-23 23:59:14 +02:00
2021-04-03 16:54:44 +02:00
return (
2021-04-23 23:59:14 +02:00
<AppContainer href={url} {...linkAttrs}>
2021-04-03 16:54:44 +02:00
<IconContainer>
<Icon name={icon} />
</IconContainer>
<DetailsContainer>
2021-04-23 23:59:14 +02:00
<AppName>{name}</AppName>
2021-04-03 16:54:44 +02:00
<AppDescription>{displayURL}</AppDescription>
</DetailsContainer>
</AppContainer>
);
2021-06-14 11:29:03 +02:00
};
export default App;