import React, { useState, forwardRef, useRef } from 'react'; import {nanoid} from 'nanoid'; import Toast from 'components/Toast'; import Dropdown from 'components/Dropdown'; import actions from 'providers/Store/actions' import { saveCollectionToIdb } from 'providers/Store/idb'; import { useStore } from 'providers/Store'; import { IconDots } from '@tabler/icons'; import CreateCollection from '../CreateCollection'; import StyledWrapper from './StyledWrapper'; const TitleBar = () => { const [modalOpen, setModalOpen] = useState(false); const [store, storeDispatch] = useStore(); const [showToast, setShowToast] = useState({show: false}); const menuDropdownTippyRef = useRef(); const onMenuDropdownCreate = (ref) => menuDropdownTippyRef.current = ref; const MenuIcon = forwardRef((props, ref) => { return (
); }); const handleCancel = () => setModalOpen(false); const handleCloseToast = () => setShowToast({show: false}); const handleConfirm = (values) => { // dispatch({ // name: values.collectionName, // type: actions.COLLECTION_CREATE // }); setModalOpen(false); if(!store.idbConnection) { setShowToast({ show: true, type: 'error', text: 'IndexedDB Error: idb connection is null' }); return; } const newCollection = { uid: nanoid(), name: values.collectionName, items: [], environments: [], userId: null }; saveCollectionToIdb(store.idbConnection, newCollection) .then(() => console.log('Collection created')) .catch((err) => { console.log(err); setShowToast({ show: true, type: 'error', text: 'IndexedDB Error: Unable to save collection' }); }); }; return ( {showToast.show && } {modalOpen ? ( ) : null}
Collections
} placement='bottom-start'>
{ menuDropdownTippyRef.current.hide(); setModalOpen(true); }}> Create Collection
{ menuDropdownTippyRef.current.hide(); }}> Import Collection
{ menuDropdownTippyRef.current.hide(); }}> Settings
) }; export default TitleBar;