#
luxiaotao1123
2024-12-03 423530a7520e544fedc80205e050d5653bb11da1
zy-acs-flow/src/page/components/ImportModal.jsx
@@ -13,19 +13,19 @@
    Form,
    Toolbar,
    useRefresh,
    useTranslate
} from 'react-admin';
import { Link } from 'react-router-dom';
import DialogCloseButton from './DialogCloseButton';
import { usePapaParse } from './usePapaParse';
export function ImportModal({ open, onClose, sampleCsv, useCodeImport }) {
const ImportModal = ({ open, onClose, importTemp, useCodeImport, onceBatch = 10 }) => {
    const refresh = useRefresh();
    const SAMPLE_URL = `data:text/csv;name=crm_contacts_sample.csv;charset=utf-8,${encodeURIComponent(sampleCsv.default)}`;
    const translate = useTranslate();
    const { processBatch } = useCodeImport();
    const { importer, parseCsv, reset } = usePapaParse({
        batchSize: 10,
        batchSize: onceBatch,
        processBatch,
    });
@@ -62,7 +62,7 @@
    return (
        <Dialog open={open} maxWidth="md" fullWidth>
            <DialogCloseButton onClose={handleClose} />
            <DialogTitle>Import</DialogTitle>
            <DialogTitle>{translate('common.action.import.title')}</DialogTitle>
            <DialogContent>
                <Form>
                    <Stack spacing={2}>
@@ -90,8 +90,7 @@
                                        },
                                    }}
                                >
                                    The import is running, please do not close
                                    this tab.
                                    {translate('common.action.import.tips')}
                                </Alert>
                                <Typography variant="body2">
                                    Imported{' '}
@@ -117,7 +116,7 @@
                                                onClick={handleReset}
                                                color="error"
                                            >
                                                Stop import
                                                {translate('common.action.import.stop')}
                                            </MuiLink>
                                        </>
                                    )}
@@ -127,16 +126,16 @@
                        {importer.state === 'error' && (
                            <Alert severity="error">
                                Failed to import this file, please make sure
                                your provided a valid CSV file.
                                {translate('common.action.import.err')}
                            </Alert>
                        )}
                        {importer.state === 'complete' && (
                            <Alert severity="success">
                                Contacts import complete. Imported{' '}
                                {importer.importCount} contacts, with{' '}
                                {importer.errorCount} errors
                                {translate('common.action.import.result', {
                                    success: importer.importCount,
                                    error: importer.errorCount
                                })}
                            </Alert>
                        )}
@@ -147,15 +146,14 @@
                                    action={
                                        <Button
                                            component={Link}
                                            label="Download CSV sample"
                                            label="common.action.import.download"
                                            color="info"
                                            to={SAMPLE_URL}
                                            download={'crm_contacts_sample.csv'}
                                            to={importTemp}
                                            download={'import_template.csv'}
                                        />
                                    }
                                >
                                    Here is a sample CSV file you can use as a
                                    template
                                    {translate('common.action.import.msg')}
                                </Alert>
                                <FileInput
@@ -185,7 +183,7 @@
                    {importer.state === 'idle' ? (
                        <>
                            <Button
                                label="Import"
                                label="common.action.import.title"
                                variant="contained"
                                onClick={startImport}
                                disabled={!file}
@@ -193,7 +191,7 @@
                        </>
                    ) : (
                        <Button
                            label="Close"
                            label="ra.action.close"
                            onClick={handleClose}
                            disabled={importer.state === 'running'}
                        />
@@ -210,3 +208,5 @@
    return `${minutes}m ${seconds}s`;
}
export default ImportModal;