mirror of
https://github.com/navidrome/navidrome.git
synced 2025-08-10 00:52:20 +00:00
76 lines
1.6 KiB
JavaScript
76 lines
1.6 KiB
JavaScript
import React from 'react'
|
|
import DeleteIcon from '@material-ui/icons/Delete'
|
|
import { makeStyles } from '@material-ui/core/styles'
|
|
import { fade } from '@material-ui/core/styles/colorManipulator'
|
|
import clsx from 'clsx'
|
|
import { useDeleteWithConfirmController, Button, Confirm } from 'react-admin'
|
|
|
|
const useStyles = makeStyles(
|
|
(theme) => ({
|
|
deleteButton: {
|
|
color: theme.palette.error.main,
|
|
'&:hover': {
|
|
backgroundColor: fade(theme.palette.error.main, 0.12),
|
|
// Reset on mouse devices
|
|
'@media (hover: none)': {
|
|
backgroundColor: 'transparent',
|
|
},
|
|
},
|
|
},
|
|
}),
|
|
{ name: 'RaDeleteWithConfirmButton' }
|
|
)
|
|
|
|
const DeleteUserButton = (props) => {
|
|
const {
|
|
resource,
|
|
record,
|
|
basePath,
|
|
redirect = 'list',
|
|
className,
|
|
onClick,
|
|
...rest
|
|
} = props
|
|
const {
|
|
open,
|
|
loading,
|
|
handleDialogOpen,
|
|
handleDialogClose,
|
|
handleDelete,
|
|
} = useDeleteWithConfirmController({
|
|
resource,
|
|
record,
|
|
redirect,
|
|
basePath,
|
|
onClick,
|
|
})
|
|
|
|
const classes = useStyles(props)
|
|
return (
|
|
<>
|
|
<Button
|
|
onClick={handleDialogOpen}
|
|
label="ra.action.delete"
|
|
className={clsx('ra-delete-button', classes.deleteButton, className)}
|
|
key="button"
|
|
{...rest}
|
|
>
|
|
<DeleteIcon />
|
|
</Button>
|
|
<Confirm
|
|
isOpen={open}
|
|
loading={loading}
|
|
title="message.delete_user_title"
|
|
content="message.delete_user_content"
|
|
translateOptions={{
|
|
name: record.name,
|
|
}}
|
|
onConfirm={handleDelete}
|
|
onClose={handleDialogClose}
|
|
/>
|
|
</>
|
|
)
|
|
}
|
|
|
|
export default DeleteUserButton
|