import React, { useState } from 'react' import { useDispatch, useSelector } from 'react-redux' import { useCreate, useDataProvider, useNotify, useTranslate, } from 'react-admin' import { Button, Dialog, DialogActions, DialogContent, DialogTitle, } from '@material-ui/core' import { closeAddToPlaylist } from './dialogState' import SelectPlaylistInput from './SelectPlaylistInput' const AddToPlaylistDialog = () => { const { open, selectedIds, onSuccess } = useSelector( (state) => state.addToPlaylistDialog ) const dispatch = useDispatch() const translate = useTranslate() const notify = useNotify() const [value, setValue] = useState({}) const dataProvider = useDataProvider() const [createAndAddToPlaylist] = useCreate( 'playlist', { name: value.name }, { onSuccess: ({ data }) => { setValue(data) addToPlaylist(data.id) }, onFailure: (error) => notify(`Error: ${error.message}`, 'warning'), } ) const addToPlaylist = (playlistId) => { dataProvider .create('playlistTrack', { data: { ids: selectedIds }, filter: { playlist_id: playlistId }, }) .then(() => { const len = selectedIds.length notify('message.songsAddedToPlaylist', 'info', { smart_count: len }) onSuccess && onSuccess(value, len) }) .catch(() => { notify('ra.page.error', 'warning') }) } const handleSubmit = (e) => { if (value.id) { addToPlaylist(value.id) } else { createAndAddToPlaylist() } dispatch(closeAddToPlaylist()) e.stopPropagation() } const handleClickClose = (e) => { dispatch(closeAddToPlaylist()) e.stopPropagation() } const handleChange = (pls) => { setValue(pls) } return ( {translate('resources.playlist.actions.selectPlaylist')} ) } export default AddToPlaylistDialog