86 lines
2.8 KiB
TypeScript
86 lines
2.8 KiB
TypeScript
import getEggs from '@/api/admin/nests/getEggs';
|
|
import importEgg from '@/api/admin/nests/importEgg';
|
|
import useFlash from '@/plugins/useFlash';
|
|
import { jsonLanguage } from '@codemirror/lang-json';
|
|
import Editor from '@/components/elements/Editor';
|
|
import React, { useState } from 'react';
|
|
import Button from '@/components/elements/Button';
|
|
import Modal from '@/components/elements/Modal';
|
|
import FlashMessageRender from '@/components/FlashMessageRender';
|
|
import { useRouteMatch } from 'react-router-dom';
|
|
import tw from 'twin.macro';
|
|
|
|
export default ({ className }: { className?: string }) => {
|
|
const [ visible, setVisible ] = useState(false);
|
|
|
|
const { clearFlashes } = useFlash();
|
|
|
|
const match = useRouteMatch<{ nestId: string }>();
|
|
const { mutate } = getEggs(Number(match.params.nestId));
|
|
|
|
let fetchFileContent: (() => Promise<string>) | null = null;
|
|
|
|
const submit = async () => {
|
|
clearFlashes('egg:import');
|
|
|
|
if (fetchFileContent === null) {
|
|
return;
|
|
}
|
|
|
|
const egg = await importEgg(Number(match.params.nestId), await fetchFileContent());
|
|
await mutate(data => ({ ...data!, items: [ ...data!.items!, egg ] }));
|
|
setVisible(false);
|
|
};
|
|
|
|
return (
|
|
<>
|
|
<Modal
|
|
visible={visible}
|
|
onDismissed={() => {
|
|
setVisible(false);
|
|
}}
|
|
>
|
|
<FlashMessageRender byKey={'egg:import'} css={tw`mb-6`}/>
|
|
|
|
<h2 css={tw`mb-6 text-2xl text-neutral-100`}>Import Egg</h2>
|
|
|
|
<Editor
|
|
overrides={tw`h-64 rounded`}
|
|
initialContent={''}
|
|
mode={jsonLanguage}
|
|
fetchContent={value => {
|
|
fetchFileContent = value;
|
|
}}
|
|
/>
|
|
|
|
<div css={tw`flex flex-wrap justify-end mt-4 sm:mt-6`}>
|
|
<Button
|
|
type={'button'}
|
|
css={tw`w-full sm:w-auto sm:mr-2`}
|
|
onClick={() => setVisible(false)}
|
|
isSecondary
|
|
>
|
|
Cancel
|
|
</Button>
|
|
<Button
|
|
css={tw`w-full sm:w-auto mt-4 sm:mt-0`}
|
|
onClick={submit}
|
|
>
|
|
Import Egg
|
|
</Button>
|
|
</div>
|
|
</Modal>
|
|
|
|
<Button
|
|
type={'button'}
|
|
size={'large'}
|
|
css={tw`h-10 px-4 py-0 whitespace-nowrap`}
|
|
className={className}
|
|
onClick={() => setVisible(true)}
|
|
isSecondary
|
|
>
|
|
Import
|
|
</Button>
|
|
</>
|
|
);
|
|
};
|