2021-06-14 11:29:03 +02:00
|
|
|
import AppCategory, { IAppCategoryProps } from "./appCategory";
|
2021-03-05 22:00:32 +01:00
|
|
|
import { IAppProps } from "./app";
|
2020-07-08 19:36:36 +02:00
|
|
|
|
2021-03-05 22:00:32 +01:00
|
|
|
import { Headline, ListContainer } from "./elements";
|
2020-07-08 19:36:36 +02:00
|
|
|
|
2021-03-05 22:00:32 +01:00
|
|
|
export interface IAppListProps {
|
2021-06-24 12:25:25 +02:00
|
|
|
categories?: Array<IAppCategoryProps>;
|
|
|
|
apps?: Array<IAppProps>;
|
2021-03-05 22:00:32 +01:00
|
|
|
}
|
2020-07-10 00:17:18 +02:00
|
|
|
|
2021-03-21 19:59:18 +01:00
|
|
|
/**
|
|
|
|
* Renders one list containing all app categories and uncategorized apps
|
2021-06-14 11:29:03 +02:00
|
|
|
* @param {IAppListProps} props props of the given list of apps
|
|
|
|
* @returns {React.ReactNode} the app list component
|
2021-03-21 19:59:18 +01:00
|
|
|
*/
|
2021-06-24 12:25:25 +02:00
|
|
|
const AppList = ({ categories, apps }: IAppListProps) => {
|
|
|
|
if (apps || categories) {
|
|
|
|
return (
|
|
|
|
<ListContainer>
|
|
|
|
<Headline>Applications</Headline>
|
|
|
|
{categories &&
|
2021-06-30 00:56:01 +02:00
|
|
|
categories.map(({ name, items }, index) => (
|
|
|
|
<AppCategory
|
|
|
|
key={[name, index].join("")}
|
|
|
|
name={name}
|
|
|
|
items={items}
|
|
|
|
/>
|
2021-06-24 12:25:25 +02:00
|
|
|
))}
|
|
|
|
{apps && (
|
|
|
|
<AppCategory
|
|
|
|
name={categories ? "Uncategorized apps" : ""}
|
|
|
|
items={apps}
|
|
|
|
/>
|
|
|
|
)}
|
|
|
|
</ListContainer>
|
|
|
|
);
|
|
|
|
} else {
|
|
|
|
return <></>;
|
|
|
|
}
|
|
|
|
};
|
2020-07-08 19:36:36 +02:00
|
|
|
|
|
|
|
export default AppList;
|