dashboard/src/components/app.tsx

64 lines
1.2 KiB
TypeScript
Raw Normal View History

2020-07-08 19:36:36 +02:00
import React from "react";
import Icon from "./icon";
import styled from "styled-components";
import selectedTheme from "./themeManager";
const AppContainer = styled.div`
display: flex;
flex: auto 25%;
padding: 1rem;
`;
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;
`;
const AppLink = styled.a`
flex: 1 0 auto;
color: ${selectedTheme.mainColor};
font-weight: 500;
text-transform: uppercase;
margin: 0;
text-decoration: none;
font-size: 1rem;
&:hover {
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;
2020-07-10 00:17:18 +02:00
URL: string;
2020-07-08 19:36:36 +02:00
displayURL: string;
}
2020-07-10 00:17:18 +02:00
export const App = ({ name, icon, URL, displayURL }: IAppProps) => (
2020-07-08 19:36:36 +02:00
<AppContainer>
<IconContainer>
2020-07-09 16:22:18 +02:00
<Icon name={icon} />
2020-07-08 19:36:36 +02:00
</IconContainer>
<DetailsContainer>
2020-07-10 00:17:18 +02:00
<AppLink href={URL}>{name}</AppLink>
2020-07-08 19:36:36 +02:00
<AppDescription>{displayURL}</AppDescription>
</DetailsContainer>
</AppContainer>
);