mirror of
https://github.com/usebruno/bruno.git
synced 2024-11-24 17:03:47 +01:00
feat: refactored import collection
This commit is contained in:
parent
c3fa473dae
commit
bf4c26de33
1
.gitignore
vendored
1
.gitignore
vendored
@ -17,6 +17,7 @@ chrome-extension
|
|||||||
chrome-extension.pem
|
chrome-extension.pem
|
||||||
chrome-extension.crx
|
chrome-extension.crx
|
||||||
bruno.zip
|
bruno.zip
|
||||||
|
*.zip
|
||||||
|
|
||||||
# misc
|
# misc
|
||||||
.DS_Store
|
.DS_Store
|
||||||
|
@ -144,6 +144,13 @@ const Wrapper = styled.div`
|
|||||||
border-bottom-left-radius: 3px;
|
border-bottom-left-radius: 3px;
|
||||||
border-bottom-right-radius: 3px;
|
border-bottom-right-radius: 3px;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
&.modal-footer-none {
|
||||||
|
.bruno-modal-content {
|
||||||
|
border-bottom-left-radius: 4px;
|
||||||
|
border-bottom-right-radius: 4px;
|
||||||
|
}
|
||||||
|
}
|
||||||
`;
|
`;
|
||||||
|
|
||||||
export default Wrapper;
|
export default Wrapper;
|
||||||
|
@ -64,6 +64,9 @@ const Modal = ({ size, title, confirmText, cancelText, handleCancel, handleConfi
|
|||||||
if (isClosing) {
|
if (isClosing) {
|
||||||
classes += ' modal--animate-out';
|
classes += ' modal--animate-out';
|
||||||
}
|
}
|
||||||
|
if(hideFooter) {
|
||||||
|
classes += ' modal-footer-none';
|
||||||
|
}
|
||||||
return (
|
return (
|
||||||
<StyledWrapper className={classes}>
|
<StyledWrapper className={classes}>
|
||||||
<div className={`bruno-modal-card modal-${size}`}>
|
<div className={`bruno-modal-card modal-${size}`}>
|
||||||
|
@ -0,0 +1,40 @@
|
|||||||
|
import React from 'react';
|
||||||
|
import { useDispatch, useSelector } from 'react-redux';
|
||||||
|
import { collectionImported } from 'providers/ReduxStore/slices/collections';
|
||||||
|
import importBrunoCollection from 'utils/importers/bruno-collection';
|
||||||
|
import { addCollectionToWorkspace } from 'providers/ReduxStore/slices/workspaces/actions';
|
||||||
|
import { toastError } from 'utils/common/error';
|
||||||
|
import toast from 'react-hot-toast';
|
||||||
|
import Modal from 'components/Modal';
|
||||||
|
|
||||||
|
const ImportCollection = ({ onClose }) => {
|
||||||
|
const dispatch = useDispatch();
|
||||||
|
const { activeWorkspaceUid } = useSelector((state) => state.workspaces);
|
||||||
|
|
||||||
|
const handleImportBrunoCollection = () => {
|
||||||
|
importBrunoCollection()
|
||||||
|
.then((collection) => {
|
||||||
|
dispatch(collectionImported({ collection: collection }));
|
||||||
|
dispatch(addCollectionToWorkspace(activeWorkspaceUid, collection.uid));
|
||||||
|
toast.success('Collection imported successfully');
|
||||||
|
onClose();
|
||||||
|
})
|
||||||
|
.catch((err) => toastError(err, 'Import collection failed'));
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<Modal size="sm" title="Import Collection" hideFooter={true} handleConfirm={onClose} handleCancel={onClose}>
|
||||||
|
<div>
|
||||||
|
<div
|
||||||
|
className='text-link hover:underline cursor-pointer'
|
||||||
|
onClick={handleImportBrunoCollection}
|
||||||
|
>
|
||||||
|
Bruno Collection
|
||||||
|
</div>
|
||||||
|
<div className='text-link hover:underline cursor-pointer mt-2'>Postman Collection</div>
|
||||||
|
</div>
|
||||||
|
</Modal>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
export default ImportCollection;
|
@ -2,8 +2,8 @@ import toast from 'react-hot-toast';
|
|||||||
import Bruno from 'components/Bruno';
|
import Bruno from 'components/Bruno';
|
||||||
import Dropdown from 'components/Dropdown';
|
import Dropdown from 'components/Dropdown';
|
||||||
import CreateCollection from '../CreateCollection';
|
import CreateCollection from '../CreateCollection';
|
||||||
import importCollection from 'utils/collections/import';
|
|
||||||
import SelectCollection from 'components/Sidebar/Collections/SelectCollection';
|
import SelectCollection from 'components/Sidebar/Collections/SelectCollection';
|
||||||
|
import ImportCollection from 'components/Sidebar/ImportCollection';
|
||||||
|
|
||||||
import { IconDots } from '@tabler/icons';
|
import { IconDots } from '@tabler/icons';
|
||||||
import { IconFolders } from '@tabler/icons';
|
import { IconFolders } from '@tabler/icons';
|
||||||
@ -11,13 +11,13 @@ import { isElectron } from 'utils/common/platform';
|
|||||||
import { useState, forwardRef, useRef } from 'react';
|
import { useState, forwardRef, useRef } from 'react';
|
||||||
import { useSelector, useDispatch } from 'react-redux';
|
import { useSelector, useDispatch } from 'react-redux';
|
||||||
import { showHomePage } from 'providers/ReduxStore/slices/app';
|
import { showHomePage } from 'providers/ReduxStore/slices/app';
|
||||||
import { collectionImported } from 'providers/ReduxStore/slices/collections';
|
|
||||||
import { openLocalCollection } from 'providers/ReduxStore/slices/collections/actions';
|
import { openLocalCollection } from 'providers/ReduxStore/slices/collections/actions';
|
||||||
import { addCollectionToWorkspace } from 'providers/ReduxStore/slices/workspaces/actions';
|
import { addCollectionToWorkspace } from 'providers/ReduxStore/slices/workspaces/actions';
|
||||||
import StyledWrapper from './StyledWrapper';
|
import StyledWrapper from './StyledWrapper';
|
||||||
|
|
||||||
const TitleBar = () => {
|
const TitleBar = () => {
|
||||||
const [createCollectionModalOpen, setCreateCollectionModalOpen] = useState(false);
|
const [createCollectionModalOpen, setCreateCollectionModalOpen] = useState(false);
|
||||||
|
const [importCollectionModalOpen, setImportCollectionModalOpen] = useState(false);
|
||||||
const [addCollectionToWSModalOpen, setAddCollectionToWSModalOpen] = useState(false);
|
const [addCollectionToWSModalOpen, setAddCollectionToWSModalOpen] = useState(false);
|
||||||
const { activeWorkspaceUid } = useSelector((state) => state.workspaces);
|
const { activeWorkspaceUid } = useSelector((state) => state.workspaces);
|
||||||
const isPlatformElectron = isElectron();
|
const isPlatformElectron = isElectron();
|
||||||
@ -48,18 +48,10 @@ const TitleBar = () => {
|
|||||||
.catch(() => toast.error('An error occured while adding collection to workspace'));
|
.catch(() => toast.error('An error occured while adding collection to workspace'));
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleImportCollection = () => {
|
|
||||||
importCollection()
|
|
||||||
.then((collection) => {
|
|
||||||
dispatch(collectionImported({ collection: collection }));
|
|
||||||
dispatch(addCollectionToWorkspace(activeWorkspaceUid, collection.uid));
|
|
||||||
})
|
|
||||||
.catch((err) => console.log(err));
|
|
||||||
};
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<StyledWrapper className="px-2 py-2">
|
<StyledWrapper className="px-2 py-2">
|
||||||
{createCollectionModalOpen ? <CreateCollection isLocal={createCollectionModalOpen === 'local' ? true : false} onClose={() => setCreateCollectionModalOpen(false)} /> : null}
|
{createCollectionModalOpen ? <CreateCollection isLocal={createCollectionModalOpen === 'local' ? true : false} onClose={() => setCreateCollectionModalOpen(false)} /> : null}
|
||||||
|
{importCollectionModalOpen ? <ImportCollection onClose={() => setImportCollectionModalOpen(false)} /> : null}
|
||||||
|
|
||||||
{addCollectionToWSModalOpen ? (
|
{addCollectionToWSModalOpen ? (
|
||||||
<SelectCollection title="Add Collection to Workspace" onClose={() => setAddCollectionToWSModalOpen(false)} onSelect={handleAddCollectionToWorkspace} />
|
<SelectCollection title="Add Collection to Workspace" onClose={() => setAddCollectionToWSModalOpen(false)} onSelect={handleAddCollectionToWorkspace} />
|
||||||
@ -91,7 +83,7 @@ const TitleBar = () => {
|
|||||||
className="dropdown-item"
|
className="dropdown-item"
|
||||||
onClick={(e) => {
|
onClick={(e) => {
|
||||||
menuDropdownTippyRef.current.hide();
|
menuDropdownTippyRef.current.hide();
|
||||||
handleImportCollection();
|
setImportCollectionModalOpen(true);
|
||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
Import Collection
|
Import Collection
|
||||||
|
@ -10,13 +10,15 @@ import { IconBrandGithub, IconPlus, IconUpload, IconFiles, IconFolders, IconPlay
|
|||||||
import Bruno from 'components/Bruno';
|
import Bruno from 'components/Bruno';
|
||||||
import CreateCollection from 'components/Sidebar/CreateCollection';
|
import CreateCollection from 'components/Sidebar/CreateCollection';
|
||||||
import SelectCollection from 'components/Sidebar/Collections/SelectCollection';
|
import SelectCollection from 'components/Sidebar/Collections/SelectCollection';
|
||||||
import importCollection, { importSampleCollection } from 'utils/collections/import';
|
import { importSampleCollection } from 'utils/importers/bruno-collection';
|
||||||
|
import ImportCollection from 'components/Sidebar/ImportCollection';
|
||||||
import StyledWrapper from './StyledWrapper';
|
import StyledWrapper from './StyledWrapper';
|
||||||
|
|
||||||
const Welcome = () => {
|
const Welcome = () => {
|
||||||
const dispatch = useDispatch();
|
const dispatch = useDispatch();
|
||||||
const [createCollectionModalOpen, setCreateCollectionModalOpen] = useState(false);
|
const [createCollectionModalOpen, setCreateCollectionModalOpen] = useState(false);
|
||||||
const [addCollectionToWSModalOpen, setAddCollectionToWSModalOpen] = useState(false);
|
const [addCollectionToWSModalOpen, setAddCollectionToWSModalOpen] = useState(false);
|
||||||
|
const [importCollectionModalOpen, setImportCollectionModalOpen] = useState(false);
|
||||||
const { activeWorkspaceUid } = useSelector((state) => state.workspaces);
|
const { activeWorkspaceUid } = useSelector((state) => state.workspaces);
|
||||||
const isPlatformElectron = isElectron();
|
const isPlatformElectron = isElectron();
|
||||||
|
|
||||||
@ -29,15 +31,6 @@ const Welcome = () => {
|
|||||||
.catch(() => toast.error('An error occured while adding collection to workspace'));
|
.catch(() => toast.error('An error occured while adding collection to workspace'));
|
||||||
};
|
};
|
||||||
|
|
||||||
const handleImportCollection = () => {
|
|
||||||
importCollection()
|
|
||||||
.then((collection) => {
|
|
||||||
dispatch(collectionImported({ collection: collection }));
|
|
||||||
dispatch(addCollectionToWorkspace(activeWorkspaceUid, collection.uid));
|
|
||||||
})
|
|
||||||
.catch((err) => console.log(err));
|
|
||||||
};
|
|
||||||
|
|
||||||
const handleImportSampleCollection = () => {
|
const handleImportSampleCollection = () => {
|
||||||
importSampleCollection()
|
importSampleCollection()
|
||||||
.then((collection) => {
|
.then((collection) => {
|
||||||
@ -58,6 +51,7 @@ const Welcome = () => {
|
|||||||
return (
|
return (
|
||||||
<StyledWrapper className="pb-4 px-6 mt-6">
|
<StyledWrapper className="pb-4 px-6 mt-6">
|
||||||
{createCollectionModalOpen ? <CreateCollection isLocal={createCollectionModalOpen === 'local' ? true : false} onClose={() => setCreateCollectionModalOpen(false)} /> : null}
|
{createCollectionModalOpen ? <CreateCollection isLocal={createCollectionModalOpen === 'local' ? true : false} onClose={() => setCreateCollectionModalOpen(false)} /> : null}
|
||||||
|
{importCollectionModalOpen ? <ImportCollection onClose={() => setImportCollectionModalOpen(false)} /> : null}
|
||||||
|
|
||||||
{addCollectionToWSModalOpen ? (
|
{addCollectionToWSModalOpen ? (
|
||||||
<SelectCollection title="Add Collection to Workspace" onClose={() => setAddCollectionToWSModalOpen(false)} onSelect={handleAddCollectionToWorkspace} />
|
<SelectCollection title="Add Collection to Workspace" onClose={() => setAddCollectionToWSModalOpen(false)} onSelect={handleAddCollectionToWorkspace} />
|
||||||
@ -83,7 +77,7 @@ const Welcome = () => {
|
|||||||
Add Collection to Workspace
|
Add Collection to Workspace
|
||||||
</span>
|
</span>
|
||||||
</div>
|
</div>
|
||||||
<div className="flex items-center ml-6" onClick={handleImportCollection}>
|
<div className="flex items-center ml-6" onClick={() => setImportCollectionModalOpen(true)}>
|
||||||
<IconUpload size={18} strokeWidth={2} />
|
<IconUpload size={18} strokeWidth={2} />
|
||||||
<span className="label ml-2" id="import-collection">Import Collection</span>
|
<span className="label ml-2" id="import-collection">Import Collection</span>
|
||||||
</div>
|
</div>
|
||||||
|
@ -1,11 +1,11 @@
|
|||||||
import each from 'lodash/each';
|
import each from 'lodash/each';
|
||||||
import get from 'lodash/get';
|
import get from 'lodash/get';
|
||||||
import fileDialog from 'file-dialog';
|
import fileDialog from 'file-dialog';
|
||||||
import toast from 'react-hot-toast';
|
|
||||||
import cloneDeep from 'lodash/cloneDeep';
|
import cloneDeep from 'lodash/cloneDeep';
|
||||||
import { uuid } from 'utils/common';
|
import { uuid } from 'utils/common';
|
||||||
import { collectionSchema } from '@usebruno/schema';
|
import { collectionSchema } from '@usebruno/schema';
|
||||||
import { saveCollectionToIdb } from 'utils/idb';
|
import { saveCollectionToIdb } from 'utils/idb';
|
||||||
|
import { BrunoError } from 'utils/common/error';
|
||||||
import sampleCollection from './samples/sample-collection.json';
|
import sampleCollection from './samples/sample-collection.json';
|
||||||
|
|
||||||
const readFile = (files) => {
|
const readFile = (files) => {
|
||||||
@ -23,8 +23,8 @@ const parseJsonCollection = (str) => {
|
|||||||
let parsed = JSON.parse(str);
|
let parsed = JSON.parse(str);
|
||||||
return resolve(parsed);
|
return resolve(parsed);
|
||||||
} catch (err) {
|
} catch (err) {
|
||||||
toast.error('Unable to parse the collection json file');
|
console.log(err);
|
||||||
reject(err);
|
reject(new BrunoError('Unable to parse the collection json file'));
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
@ -35,8 +35,8 @@ const validateSchema = (collection = {}) => {
|
|||||||
.validate(collection)
|
.validate(collection)
|
||||||
.then(() => resolve(collection))
|
.then(() => resolve(collection))
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
toast.error('The Collection file is corrupted');
|
console.log(err);
|
||||||
reject(err);
|
reject(new BrunoError('The Collection file is corrupted'));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
};
|
};
|
||||||
@ -74,13 +74,10 @@ const importCollection = () => {
|
|||||||
.then(updateUidsInCollection)
|
.then(updateUidsInCollection)
|
||||||
.then(validateSchema)
|
.then(validateSchema)
|
||||||
.then((collection) => saveCollectionToIdb(window.__idb, collection))
|
.then((collection) => saveCollectionToIdb(window.__idb, collection))
|
||||||
.then((collection) => {
|
.then((collection) => resolve(collection))
|
||||||
toast.success('Collection imported successfully');
|
|
||||||
resolve(collection);
|
|
||||||
})
|
|
||||||
.catch((err) => {
|
.catch((err) => {
|
||||||
toast.error('Import collection failed');
|
console.log(err);
|
||||||
reject(err);
|
reject(new BrunoError('Import collection failed'));
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
};
|
};
|
Loading…
Reference in New Issue
Block a user