mirror of
https://github.com/austinried/subtracks.git
synced 2025-12-27 00:59:28 +01:00
* start of music store refactor moving stuff into a state cache better separate it from view logic * added paginated list/album list * reworked fetchAlbumList to remove ui state refactored home screen to use new method i broke playing songs somehow, JS thread goes into a loop * don't reset parts manually, do it all at once * fixed perf issue related to too many rerenders rerenders were caused by strict equality check on object/array picks switched artistInfo to new store updated zustand and fixed deprecation warnings * update typescript and use workspace tsc version for vscode * remove old artistInfo * switched to new playlist w/songs removed more unused stuff * remove unused + (slightly) rework search * refactor star * use only original/large imges for covers/artist fix view artist from context menu add loading indicators to song list and artist views (show info we have right away) * set starred/unstar assuming it works and correct state on error * reorg, remove old music slice files * added back fix for song cover art * sort artists by localCompare name * update licenses * fix now playing background grey bar * update react-native-gesture-handler for node-fetch security alert * fix another gradient height grey bar issue * update licenses again * remove thumbnail cache * rename to remove "Library" from methods * Revert "remove thumbnail cache" This reverts commit e0db4931f11bbf4cd8e73102d06505c6ae85f4a6. * use ids for lists, pull state later * Revert "use only original/large imges for covers/artist" This reverts commit c9aea9065ce6ebe3c8b09c10dd74d4de153d76fd. * deep equal ListItem props for now this needs a bigger refactor * use immer as middleware * refactor api client to use string method hoping to use this for requestKey/deduping next * use thumbnails in list items * Revert "refactor api client to use string method" This reverts commit 234326135b7af96cb91b941e7ca515f45c632556. * rename/cleanup * store servers by id * get rid of settings selectors * renames for clarity remove unused estimateContentLength setting * remove trackplayer selectors * fix migration for library filter settings * fixed shuffle order reporting wrong track/queue * removed the other selectors * don't actually need es6/react for our state * fix slow artist sort on star localeCompare is too slow for large lists
31 lines
980 B
TypeScript
31 lines
980 B
TypeScript
import { useStar } from '@app/hooks/library'
|
|
import colors from '@app/styles/colors'
|
|
import React from 'react'
|
|
import { PressableStateCallbackType, StyleProp, ViewStyle } from 'react-native'
|
|
import IconFA from 'react-native-vector-icons/FontAwesome'
|
|
import PressableOpacity from './PressableOpacity'
|
|
|
|
export const Star = React.memo<{
|
|
starred: boolean
|
|
size: number
|
|
}>(({ starred, size }) => {
|
|
return (
|
|
<IconFA name={starred ? 'star' : 'star-o'} color={starred ? colors.accent : colors.text.secondary} size={size} />
|
|
)
|
|
})
|
|
|
|
export const PressableStar = React.memo<{
|
|
id: string
|
|
type: 'album' | 'artist' | 'song'
|
|
size: number
|
|
style?: StyleProp<ViewStyle> | ((state: PressableStateCallbackType) => StyleProp<ViewStyle>) | undefined
|
|
}>(({ id, type, size, style }) => {
|
|
const { starred, toggleStar } = useStar(id, type)
|
|
|
|
return (
|
|
<PressableOpacity onPress={toggleStar} style={style}>
|
|
<Star size={size} starred={starred} />
|
|
</PressableOpacity>
|
|
)
|
|
})
|