mirror of
https://github.com/ajnart/homarr.git
synced 2025-11-12 00:15:48 +01:00
85 lines
2.6 KiB
TypeScript
85 lines
2.6 KiB
TypeScript
import { ActionIcon, Drawer, Group, LoadingOverlay, Text } from '@mantine/core';
|
|
import axios from 'axios';
|
|
import { useEffect, useState } from 'react';
|
|
import Docker from 'dockerode';
|
|
import { IconBrandDocker, IconX } from '@tabler/icons';
|
|
import { showNotification } from '@mantine/notifications';
|
|
import ContainerActionBar from './ContainerActionBar';
|
|
import DockerTable from './DockerTable';
|
|
import { useConfig } from '../../../tools/state';
|
|
import { IModule } from '../modules';
|
|
|
|
export const DockerModule: IModule = {
|
|
title: 'Docker',
|
|
description: 'Allows you to easily manage your torrents',
|
|
icon: IconBrandDocker,
|
|
component: DockerMenuButton,
|
|
};
|
|
|
|
export default function DockerMenuButton(props: any) {
|
|
const [opened, setOpened] = useState(false);
|
|
const [containers, setContainers] = useState<Docker.ContainerInfo[]>([]);
|
|
const [selection, setSelection] = useState<Docker.ContainerInfo[]>([]);
|
|
const [visible, setVisible] = useState(false);
|
|
const { config } = useConfig();
|
|
const moduleEnabled = config.modules?.[DockerModule.title]?.enabled ?? false;
|
|
|
|
useEffect(() => {
|
|
reload();
|
|
}, [config.modules]);
|
|
|
|
function reload() {
|
|
if (!moduleEnabled) {
|
|
return;
|
|
}
|
|
setVisible(true);
|
|
setTimeout(() => {
|
|
axios
|
|
.get('/api/docker/containers')
|
|
.then((res) => {
|
|
setContainers(res.data);
|
|
setSelection([]);
|
|
setVisible(false);
|
|
})
|
|
.catch(() =>
|
|
// Send an Error notification
|
|
showNotification({
|
|
autoClose: 1500,
|
|
title: <Text>Docker integration failed</Text>,
|
|
color: 'red',
|
|
icon: <IconX />,
|
|
message: 'Did you forget to mount the docker socket ?',
|
|
})
|
|
);
|
|
}, 300);
|
|
}
|
|
const exists = config.modules?.[DockerModule.title]?.enabled ?? false;
|
|
if (!exists) {
|
|
return null;
|
|
}
|
|
// Check if the user has at least one container
|
|
if (containers.length < 1) return null;
|
|
return (
|
|
<>
|
|
<Drawer opened={opened} onClose={() => setOpened(false)} padding="xl" size="full">
|
|
<ContainerActionBar selected={selection} reload={reload} />
|
|
<div style={{ position: 'relative' }}>
|
|
<LoadingOverlay transitionDuration={500} visible={visible} />
|
|
<DockerTable containers={containers} selection={selection} setSelection={setSelection} />
|
|
</div>
|
|
</Drawer>
|
|
<Group position="center">
|
|
<ActionIcon
|
|
variant="default"
|
|
radius="md"
|
|
size="xl"
|
|
color="blue"
|
|
onClick={() => setOpened(true)}
|
|
>
|
|
<IconBrandDocker />
|
|
</ActionIcon>
|
|
</Group>
|
|
</>
|
|
);
|
|
}
|