import getAllocations from '@/api/admin/nodes/getAllocations'; import { Server } from '@/api/admin/servers/getServers'; import ServerDeleteButton from '@/components/admin/servers/ServerDeleteButton'; import Label from '@/components/elements/Label'; import Select from '@/components/elements/Select'; import SelectField, { AsyncSelectField, Option } from '@/components/elements/SelectField'; import { faBalanceScale, faCogs, faConciergeBell, faNetworkWired } from '@fortawesome/free-solid-svg-icons'; import React from 'react'; import AdminBox from '@/components/admin/AdminBox'; import { useHistory } from 'react-router-dom'; import tw from 'twin.macro'; import { object } from 'yup'; import updateServer, { Values } from '@/api/admin/servers/updateServer'; import Field from '@/components/elements/Field'; import SpinnerOverlay from '@/components/elements/SpinnerOverlay'; import { Form, Formik, FormikHelpers, useFormikContext } from 'formik'; import { Context } from '@/components/admin/servers/ServerRouter'; import { ApplicationStore } from '@/state'; import { Actions, useStoreActions } from 'easy-peasy'; import OwnerSelect from '@/components/admin/servers/OwnerSelect'; import Button from '@/components/elements/Button'; import FormikSwitch from '@/components/elements/FormikSwitch'; export function ServerFeatureContainer () { const { isSubmitting } = useFormikContext(); return (
); } export function ServerResourceContainer () { const { isSubmitting } = useFormikContext(); return (
); } export function ServerSettingsContainer ({ server }: { server?: Server }) { const { isSubmitting } = useFormikContext(); return (
); } export function ServerAllocationsContainer ({ server }: { server: Server }) { const { isSubmitting } = useFormikContext(); const loadOptions = async (inputValue: string, callback: (options: Option[]) => void) => { const allocations = await getAllocations(server.nodeId, { ip: inputValue, server_id: '0' }); callback(allocations.map(a => { return { value: a.id.toString(), label: a.ip + ':' + a.port }; })); }; return (
{ return { value: a.id.toString(), label: a.ip + ':' + a.port }; }) || []} isMulti isSearchable css={tw`mb-2`} />
); } type Values2 = Omit & { oomKiller: boolean }; export default function ServerSettingsContainer2 () { const history = useHistory(); const { clearFlashes, clearAndAddHttpError } = useStoreActions((actions: Actions) => actions.flashes); const server = Context.useStoreState(state => state.server); const setServer = Context.useStoreActions(actions => actions.setServer); if (server === undefined) { return ( <> ); } const submit = (values: Values2, { setSubmitting, setFieldValue }: FormikHelpers) => { clearFlashes('server'); updateServer(server.id, { ...values, oomDisabled: !values.oomKiller }, [ 'allocations', 'user' ]) .then(s => { setServer({ ...server, ...s }); // TODO: Figure out how to properly clear react-selects for allocations. setFieldValue('addAllocations', []); setFieldValue('removeAllocations', []); }) .catch(error => { console.error(error); clearAndAddHttpError({ key: 'server', error }); }) .then(() => setSubmitting(false)); }; return ( {({ isSubmitting, isValid }) => (
history.push('/admin/servers')} />
)}
); }