import React from 'react' import { GridList, GridListTile, Typography, GridListTileBar, useMediaQuery, } from '@material-ui/core' import { makeStyles } from '@material-ui/core/styles' import withWidth from '@material-ui/core/withWidth' import { Link } from 'react-router-dom' import { linkToRecord, useListContext, Loading } from 'react-admin' import { withContentRect } from 'react-measure' import subsonic from '../subsonic' import { AlbumContextMenu, PlayButton, ArtistLinkField, RangeField, } from '../common' const useStyles = makeStyles( (theme) => ({ root: { margin: '20px', }, tileBar: { transition: 'all 150ms ease-out', opacity: 0, textAlign: 'left', marginBottom: '3px', background: 'linear-gradient(to top, rgba(0,0,0,0.7) 0%,rgba(0,0,0,0.4) 70%,rgba(0,0,0,0) 100%)', }, tileBarMobile: { textAlign: 'left', marginBottom: '3px', background: 'linear-gradient(to top, rgba(0,0,0,0.7) 0%,rgba(0,0,0,0.4) 70%,rgba(0,0,0,0) 100%)', }, albumArtistName: { whiteSpace: 'nowrap', overflow: 'hidden', textOverflow: 'ellipsis', textAlign: 'left', fontSize: '1em', }, albumName: { fontSize: '14px', color: theme.palette.type === 'dark' ? '#eee' : 'black', overflow: 'hidden', whiteSpace: 'nowrap', textOverflow: 'ellipsis', }, albumSubtitle: { fontSize: '12px', color: theme.palette.type === 'dark' ? '#c5c5c5' : '#696969', overflow: 'hidden', whiteSpace: 'nowrap', textOverflow: 'ellipsis', }, link: { position: 'relative', display: 'block', textDecoration: 'none', '&:hover $tileBar': { opacity: 1, }, }, albumLink: { position: 'relative', display: 'block', textDecoration: 'none', }, albumContainer: {}, albumPlayButton: { color: 'white' }, }), { name: 'NDAlbumGridView' } ) const useCoverStyles = makeStyles({ cover: { display: 'inline-block', width: '100%', objectFit: 'contain', height: (props) => props.height, }, }) const getColsForWidth = (width) => { if (width === 'xs') return 2 if (width === 'sm') return 3 if (width === 'md') return 4 if (width === 'lg') return 6 return 9 } const Cover = withContentRect('bounds')( ({ album, measureRef, contentRect }) => { // Force height to be the same as the width determined by the GridList // noinspection JSSuspiciousNameCombination const classes = useCoverStyles({ height: contentRect.bounds.width }) return (
{album.name}
) } ) const AlbumGridTile = ({ showArtist, record, basePath }) => { const classes = useStyles() const isDesktop = useMediaQuery((theme) => theme.breakpoints.up('md'), { noSsr: true, }) if (!record) { return null } return (
} actionIcon={} /> {record.name} {showArtist ? ( ) : ( )}
) } const LoadedAlbumGrid = ({ ids, data, basePath, width }) => { const classes = useStyles() const { filterValues } = useListContext() const isArtistView = !!(filterValues && filterValues.artist_id) return (
{ids.map((id) => ( ))}
) } const AlbumGridView = ({ albumListType, loaded, loading, ...props }) => { const hide = (loading && albumListType === 'random') || !props.data || !props.ids return hide ? : } export default withWidth()(AlbumGridView)