Fix Album View

This commit is contained in:
Deluan
2020-11-19 18:44:28 -05:00
committed by Deluan Quintão
parent 3209430ebd
commit f5808288ab
3 changed files with 97 additions and 101 deletions
+39 -29
View File
@@ -1,40 +1,50 @@
import React from 'react' import React from 'react'
import { useGetOne } from 'react-admin' import {
import AlbumDetails from './AlbumDetails' ReferenceManyField,
import { Title } from '../common' ShowContextProvider,
import { SongBulkActions } from '../common' useShowContext,
import AlbumActions from './AlbumActions' useShowController,
} from 'react-admin'
import AlbumSongs from './AlbumSongs' import AlbumSongs from './AlbumSongs'
import AlbumDetails from './AlbumDetails'
import AlbumActions from './AlbumActions'
const AlbumShow = (props) => { const AlbumShowLayout = (props) => {
const { data: record, loading, error } = useGetOne('album', props.id) console.log('show', props)
const { loading, ...context } = useShowContext(props)
if (loading) { const { record } = context
return null
}
if (error) {
return <p>ERROR: {error}</p>
}
return ( return (
<> <>
<AlbumDetails {...props} record={record} /> {record && <AlbumDetails {...context} />}
<AlbumSongs {record && (
{...props} <ReferenceManyField
albumId={props.id} {...context}
title={<Title subTitle={record.name} />} addLabel={false}
actions={<AlbumActions record={record} />} reference="albumSong"
filter={{ album_id: props.id }} target="album_id"
resource={'albumSong'} sort={{ field: 'discNumber asc, trackNumber asc', order: 'ASC' }}
exporter={false} perPage={0}
perPage={0} pagination={null}
pagination={null} >
sort={{ field: 'discNumber asc, trackNumber asc', order: 'ASC' }} <AlbumSongs
bulkActionButtons={<SongBulkActions />} resource={'albumSong'}
/> exporter={false}
actions={<AlbumActions record={record} />}
/>
</ReferenceManyField>
)}
</> </>
) )
} }
const AlbumShow = (props) => {
const controllerProps = useShowController(props)
return (
<ShowContextProvider value={controllerProps}>
<AlbumShowLayout {...props} {...controllerProps} />
</ShowContextProvider>
)
}
export default AlbumShow export default AlbumShow
+55 -72
View File
@@ -1,10 +1,10 @@
import React from 'react' import React from 'react'
import { import {
BulkActionsToolbar, BulkActionsToolbar,
DatagridLoading,
ListToolbar, ListToolbar,
TextField, TextField,
useListController, useVersion,
useListContext,
} from 'react-admin' } from 'react-admin'
import classnames from 'classnames' import classnames from 'classnames'
import { useDispatch } from 'react-redux' import { useDispatch } from 'react-redux'
@@ -14,6 +14,7 @@ import StarBorderIcon from '@material-ui/icons/StarBorder'
import { playTracks } from '../actions' import { playTracks } from '../actions'
import { import {
DurationField, DurationField,
SongBulkActions,
SongContextMenu, SongContextMenu,
SongDatagrid, SongDatagrid,
SongDetails, SongDetails,
@@ -52,97 +53,74 @@ const useStyles = makeStyles(
marginTop: '-2px', marginTop: '-2px',
verticalAlign: 'text-top', verticalAlign: 'text-top',
}, },
toolbar: {
justifyContent: 'flex-start',
},
}), }),
{ name: 'RaList' } { name: 'RaList' }
) )
const useStylesListToolbar = makeStyles({
toolbar: {
justifyContent: 'flex-start',
},
})
const AlbumSongs = (props) => { const AlbumSongs = (props) => {
console.log('songs', props)
const listContext = props
const classes = useStyles(props) const classes = useStyles(props)
const classesToolbar = useStylesListToolbar(props)
const dispatch = useDispatch() const dispatch = useDispatch()
const isXsmall = useMediaQuery((theme) => theme.breakpoints.down('xs')) const isXsmall = useMediaQuery((theme) => theme.breakpoints.down('xs'))
const isDesktop = useMediaQuery((theme) => theme.breakpoints.up('md')) const isDesktop = useMediaQuery((theme) => theme.breakpoints.up('md'))
const controllerProps = useListController(props) const { id: album_id, data, ids } = listContext
const { bulkActionButtons, albumId, className } = props const version = useVersion()
const { data, ids, version } = controllerProps
const anySong = data[ids[0]]
const showPlaceholder = !anySong || anySong.albumId !== albumId
const hasBulkActions = props.bulkActionButtons !== false
return ( return (
<> <>
<ListToolbar <ListToolbar
classes={classesToolbar} classes={{ toolbar: classes.toolbar }}
filters={props.filters}
{...controllerProps}
actions={props.actions} actions={props.actions}
permanentFilter={props.filter} permanentFilter={{ album_id }}
{...listContext}
/> />
<div className={classes.main}> <div className={classes.main}>
<Card <Card
className={classnames(classes.content, { className={classnames(classes.content, {
[classes.bulkActionsDisplayed]: [classes.bulkActionsDisplayed]: listContext.selectedIds.length > 0,
controllerProps.selectedIds.length > 0,
})} })}
key={version} key={version}
> >
{bulkActionButtons !== false && bulkActionButtons && ( <BulkActionsToolbar {...listContext}>
<BulkActionsToolbar {...controllerProps}> <SongBulkActions />
{bulkActionButtons} </BulkActionsToolbar>
</BulkActionsToolbar> <SongDatagrid
)} expand={isXsmall ? null : <SongDetails />}
{showPlaceholder ? ( rowClick={(id) => dispatch(playTracks(data, ids, id))}
<DatagridLoading {...listContext}
classes={classes} hasBulkActions={true}
className={className} showDiscSubtitles={true}
expand={null} contextAlwaysVisible={!isDesktop}
hasBulkActions={hasBulkActions} >
nbChildren={3} {isDesktop && (
size={'small'} <TextField
source="trackNumber"
sortBy="discNumber asc, trackNumber asc"
label="#"
sortable={false}
/>
)}
<SongTitleField
source="title"
sortable={false}
showTrackNumbers={!isDesktop}
/> />
) : ( {isDesktop && <TextField source="artist" sortable={false} />}
<SongDatagrid <DurationField source="duration" sortable={false} />
expand={isXsmall ? null : <SongDetails />} <SongContextMenu
rowClick={(id) => dispatch(playTracks(data, ids, id))} source={'starred'}
{...controllerProps} sortable={false}
hasBulkActions={hasBulkActions} label={
showDiscSubtitles={true} <StarBorderIcon
contextAlwaysVisible={!isDesktop} fontSize={'small'}
> className={classes.columnIcon}
{isDesktop && (
<TextField
source="trackNumber"
sortBy="discNumber asc, trackNumber asc"
label="#"
sortable={false}
/> />
)} }
<SongTitleField />
source="title" </SongDatagrid>
sortable={false}
showTrackNumbers={!isDesktop}
/>
{isDesktop && <TextField source="artist" sortable={false} />}
<DurationField source="duration" sortable={false} />
<SongContextMenu
source={'starred'}
sortable={false}
label={
<StarBorderIcon
fontSize={'small'}
className={classes.columnIcon}
/>
}
/>
</SongDatagrid>
)}
</Card> </Card>
</div> </div>
<AddToPlaylistDialog /> <AddToPlaylistDialog />
@@ -150,4 +128,9 @@ const AlbumSongs = (props) => {
) )
} }
export default AlbumSongs const SanitizedAlbumSongs = (props) => {
const { loaded, loading, total, ...rest } = useListContext(props)
return <>{loaded && <AlbumSongs {...rest} actions={props.actions} />}</>
}
export default SanitizedAlbumSongs
+3
View File
@@ -138,6 +138,9 @@ export const SongDatagrid = ({
) )
const firstTracks = useMemo(() => { const firstTracks = useMemo(() => {
if (!ids) {
return new Set()
}
const set = new Set( const set = new Set(
ids ids
.filter((i) => data[i]) .filter((i) => data[i])