* feat: wip implement back-end call csv import * fix: rebase IconBrandTwitter missing * feat: person and company csv import * fix: test & clean * fix: clean & test
50 lines
1.4 KiB
TypeScript
50 lines
1.4 KiB
TypeScript
import styled from '@emotion/styled';
|
|
|
|
import { useSpreadsheetImportInitialStep } from '@/spreadsheet-import/hooks/useSpreadsheetImportInitialStep';
|
|
import { useSpreadsheetImportInternal } from '@/spreadsheet-import/hooks/useSpreadsheetImportInternal';
|
|
import { Modal } from '@/ui/modal/components/Modal';
|
|
import { StepBar } from '@/ui/step-bar/components/StepBar';
|
|
import { useStepBar } from '@/ui/step-bar/hooks/useStepBar';
|
|
|
|
import { UploadFlow } from './UploadFlow';
|
|
|
|
const Header = styled(Modal.Header)`
|
|
background-color: ${({ theme }) => theme.background.secondary};
|
|
border-bottom: 1px solid ${({ theme }) => theme.border.color.medium};
|
|
height: 60px;
|
|
padding: 0px;
|
|
padding-left: ${({ theme }) => theme.spacing(30)};
|
|
padding-right: ${({ theme }) => theme.spacing(30)};
|
|
`;
|
|
|
|
const stepTitles = {
|
|
uploadStep: 'Upload file',
|
|
matchColumnsStep: 'Match columns',
|
|
validationStep: 'Validate data',
|
|
} as const;
|
|
|
|
export const Steps = () => {
|
|
const { initialStepState } = useSpreadsheetImportInternal();
|
|
|
|
const { steps, initialStep } = useSpreadsheetImportInitialStep(
|
|
initialStepState?.type,
|
|
);
|
|
|
|
const { nextStep, activeStep } = useStepBar({
|
|
initialStep,
|
|
});
|
|
|
|
return (
|
|
<>
|
|
<Header>
|
|
<StepBar activeStep={activeStep}>
|
|
{steps.map((key) => (
|
|
<StepBar.Step label={stepTitles[key]} key={key} />
|
|
))}
|
|
</StepBar>
|
|
</Header>
|
|
<UploadFlow nextStep={nextStep} />
|
|
</>
|
|
);
|
|
};
|