summaryrefslogtreecommitdiff
path: root/packages/create-astro/src/components/Confirm.tsx
blob: 84d83ed8f900eaf764b3e508143c4c9e999e3b90 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
import React, { FC } from 'react';
import { Box, Text, useInput, useApp } from 'ink';
import Spacer from './Spacer';
import Select from './Select';

const Confirm: FC<{ message?: any; context: any; onSubmit: (value: boolean) => void }> = ({ message, context: { projectName }, onSubmit }) => {
  const { exit } = useApp();
  const handleSubmit = (v: boolean) => {
    if (!v) return exit();
    onSubmit(v);
  };

  return (
    <>
      <Box display="flex">
        {!message ? (
          <>
            <Text color="#FFBE2D">{'[uh-oh]'}</Text>
            <Text>
              {' '}
              It appears <Text color="#17C083">./{projectName}</Text> is not empty. Overwrite?
            </Text>
          </>
        ) : (
          message
        )}
      </Box>
      <Box display="flex">
        <Spacer width={6} />
        <Select
          items={[
            {
              value: false,
              label: 'no',
            },
            {
              value: true,
              label: 'yes',
              description: <Text color="#FF1639">overwrite</Text>,
            },
          ]}
          onSelect={handleSubmit}
        />
      </Box>
    </>
  );
};

export default Confirm;