mirror of
https://github.com/openziti/zrok.git
synced 2025-03-01 08:31:46 +01:00
release environment modal implementation (#822)
This commit is contained in:
parent
27515ece8e
commit
2d444a568d
@ -1,20 +1,80 @@
|
|||||||
import {Node} from "@xyflow/react";
|
import {Node} from "@xyflow/react";
|
||||||
import {Button, Grid2, Tooltip, Typography} from "@mui/material";
|
import {Box, Button, Checkbox, FormControlLabel, Grid2, Modal, Tooltip, Typography} from "@mui/material";
|
||||||
import EnvironmentIcon from "@mui/icons-material/Computer";
|
import EnvironmentIcon from "@mui/icons-material/Computer";
|
||||||
import {useEffect, useState} from "react";
|
import {useEffect, useRef, useState} from "react";
|
||||||
import {Configuration, Environment, MetadataApi} from "./api";
|
import {Configuration, Environment, EnvironmentApi, MetadataApi} from "./api";
|
||||||
import PropertyTable from "./PropertyTable.tsx";
|
import PropertyTable from "./PropertyTable.tsx";
|
||||||
import SecretToggle from "./SecretToggle.tsx";
|
import SecretToggle from "./SecretToggle.tsx";
|
||||||
import useStore from "./model/store.ts";
|
import useStore from "./model/store.ts";
|
||||||
import DeleteIcon from "@mui/icons-material/Delete";
|
import DeleteIcon from "@mui/icons-material/Delete";
|
||||||
|
import {modalStyle} from "./styling/theme.ts";
|
||||||
|
|
||||||
|
interface ReleaseEnvironmentProps {
|
||||||
|
close: () => void;
|
||||||
|
isOpen: boolean;
|
||||||
|
detail: Environment;
|
||||||
|
action: () => void;
|
||||||
|
}
|
||||||
|
|
||||||
|
const ReleaseEnvironmentModal = ({ close, isOpen, detail, action }: ReleaseEnvironmentProps) => {
|
||||||
|
const [description, setDescription] = useState<String>("");
|
||||||
|
const [checked, setChecked] = useState<boolean>(false);
|
||||||
|
const checkedRef = useRef<boolean>();
|
||||||
|
checkedRef.current = checked;
|
||||||
|
|
||||||
|
const toggleChecked = (event: React.ChangeEvent<HTMLInputElement>) => {
|
||||||
|
setChecked(!checkedRef.current);
|
||||||
|
}
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
setChecked(false);
|
||||||
|
}, [isOpen]);
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
if(detail && detail.description) {
|
||||||
|
setDescription(detail.description);
|
||||||
|
}
|
||||||
|
}, [detail]);
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Modal open={isOpen} onClose={close}>
|
||||||
|
<Box sx={{ ...modalStyle }}>
|
||||||
|
<Grid2 container sx={{ flexGrow: 1, p: 1 }} alignItems="center">
|
||||||
|
<Typography variant="h5"><strong>Release Environment</strong></Typography>
|
||||||
|
</Grid2>
|
||||||
|
<Grid2 container sx={{ flexGrow: 1, p: 1 }} alignItems="center">
|
||||||
|
<Typography variant="body1">Would you like to release the environment <strong>'{description}'</strong>?</Typography>
|
||||||
|
</Grid2>
|
||||||
|
<Grid2 container sx={{ flexGrow: 1, p: 1 }} alignItems="center">
|
||||||
|
<Typography variant="body1">Releasing this environment will also release any shares and accesses that are associated with it.</Typography>
|
||||||
|
</Grid2>
|
||||||
|
<Grid2 container sx={{ flexGrow: 1, p: 1 }} alignItems="center">
|
||||||
|
<FormControlLabel control={<Checkbox checked={checked} onChange={toggleChecked} />} label={"I am ready to release '" + description + "'"} sx={{ mt: 2 }} />
|
||||||
|
</Grid2>
|
||||||
|
<Grid2 container sx={{ flexGrow: 1 }} alignItems="center">
|
||||||
|
<Button color="error" variant="contained" disabled={!checked} onClick={action}>Release</Button>
|
||||||
|
</Grid2>
|
||||||
|
</Box>
|
||||||
|
</Modal>
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
interface EnvironmentPanelProps {
|
interface EnvironmentPanelProps {
|
||||||
environment: Node;
|
environment: Node;
|
||||||
}
|
}
|
||||||
|
|
||||||
const EnvironmentPanel = ({ environment }: EnvironmentPanelProps) => {
|
const EnvironmentPanel = ({environment}: EnvironmentPanelProps) => {
|
||||||
const user = useStore((state) => state.user);
|
const user = useStore((state) => state.user);
|
||||||
const [detail, setDetail] = useState<Environment>(null);
|
const [detail, setDetail] = useState<Environment>(null);
|
||||||
|
const [releaseEnvironmentOpen, setReleaseEnvironmentOpen] = useState(false);
|
||||||
|
|
||||||
|
const openReleaseEnvironment = () => {
|
||||||
|
setReleaseEnvironmentOpen(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
const closeReleaseEnvironment = () => {
|
||||||
|
setReleaseEnvironmentOpen(false);
|
||||||
|
}
|
||||||
|
|
||||||
const customProperties = {
|
const customProperties = {
|
||||||
zId: row => <SecretToggle secret={row.value} />,
|
zId: row => <SecretToggle secret={row.value} />,
|
||||||
@ -45,23 +105,44 @@ const EnvironmentPanel = ({ environment }: EnvironmentPanelProps) => {
|
|||||||
})
|
})
|
||||||
}, [environment]);
|
}, [environment]);
|
||||||
|
|
||||||
|
const releaseEnvironment = () => {
|
||||||
|
if(detail && detail.zId) {
|
||||||
|
let cfg = new Configuration({
|
||||||
|
headers: {
|
||||||
|
"X-TOKEN": user.token
|
||||||
|
}
|
||||||
|
});
|
||||||
|
let environment = new EnvironmentApi(cfg);
|
||||||
|
environment.disable({body: {identity: detail.zId}})
|
||||||
|
.then(d => {
|
||||||
|
setReleaseEnvironmentOpen(false);
|
||||||
|
})
|
||||||
|
.catch(e => {
|
||||||
|
console.log("releaseEnvironment", e);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Typography component="div">
|
<>
|
||||||
<Grid2 container sx={{ flexGrow: 1, p: 1 }} alignItems="center">
|
<Typography component="div">
|
||||||
<Grid2 display="flex"><EnvironmentIcon sx={{ fontSize: 30, mr: 0.5 }}/></Grid2>
|
<Grid2 container sx={{ flexGrow: 1, p: 1 }} alignItems="center">
|
||||||
<Grid2 display="flex" component="h3">{String(environment.data.label)}</Grid2>
|
<Grid2 display="flex"><EnvironmentIcon sx={{ fontSize: 30, mr: 0.5 }}/></Grid2>
|
||||||
</Grid2>
|
<Grid2 display="flex" component="h3">{String(environment.data.label)}</Grid2>
|
||||||
<Grid2 container sx={{ flexGrow: 1, mb: 3 }} alignItems="left">
|
|
||||||
<Tooltip title="Release Environment">
|
|
||||||
<Button variant="contained" color="error"><DeleteIcon /></Button>
|
|
||||||
</Tooltip>
|
|
||||||
</Grid2>
|
|
||||||
<Grid2 container sx={{ flexGrow: 1 }}>
|
|
||||||
<Grid2 display="flex">
|
|
||||||
<PropertyTable object={detail} custom={customProperties} labels={labels} />
|
|
||||||
</Grid2>
|
</Grid2>
|
||||||
</Grid2>
|
<Grid2 container sx={{ flexGrow: 1, mb: 3 }} alignItems="left">
|
||||||
</Typography>
|
<Tooltip title="Release Environment">
|
||||||
|
<Button variant="contained" color="error" onClick={openReleaseEnvironment}><DeleteIcon /></Button>
|
||||||
|
</Tooltip>
|
||||||
|
</Grid2>
|
||||||
|
<Grid2 container sx={{ flexGrow: 1 }}>
|
||||||
|
<Grid2 display="flex">
|
||||||
|
<PropertyTable object={detail} custom={customProperties} labels={labels} />
|
||||||
|
</Grid2>
|
||||||
|
</Grid2>
|
||||||
|
</Typography>
|
||||||
|
<ReleaseEnvironmentModal close={closeReleaseEnvironment} isOpen={releaseEnvironmentOpen} detail={detail} action={releaseEnvironment} />
|
||||||
|
</>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,4 +44,5 @@ export const modalStyle = {
|
|||||||
bgcolor: 'background.paper',
|
bgcolor: 'background.paper',
|
||||||
boxShadow: 24,
|
boxShadow: 24,
|
||||||
p: 4,
|
p: 4,
|
||||||
|
borderRadius: 2,
|
||||||
};
|
};
|
Loading…
Reference in New Issue
Block a user