// @flow import * as ICONS from 'constants/icons'; import React from 'react'; import { FormField } from 'component/common/form'; import Icon from 'component/common/icon'; import { COLLECTIONS_CONSTS } from 'lbry-redux'; type Props = { collection: Collection, hasClaim: boolean, category: string, edited: boolean, editCollection: (string, CollectionEditParams) => void, claim: Claim, collectionPending: Collection, setSelectedCollections: (any) => void, selectedCollections: Array, items: Array, }; function CollectionSelectItem(props: Props) { const { collection, hasClaim, category, editCollection, claim, collectionPending, setSelectedCollections, selectedCollections, items, } = props; const { name, id } = collection; const justAdded = selectedCollections.includes(name); const [active, setActive] = React.useState(justAdded); const handleChange = () => { if (items) { if (active) { selectedCollections.splice(selectedCollections.indexOf(id), 1); setSelectedCollections([...selectedCollections]); } else { setSelectedCollections([...selectedCollections, id]); } setActive(!active); } else { editCollection(id, { claims: [claim], remove: hasClaim }); } }; let icon; switch (category) { case 'builtin': icon = (id === COLLECTIONS_CONSTS.WATCH_LATER_ID && ICONS.TIME) || (id === COLLECTIONS_CONSTS.FAVORITES_ID && ICONS.STAR) || ICONS.STACK; break; case 'published': icon = ICONS.STACK; break; default: // 'unpublished' icon = ICONS.LOCK; break; } return (
{`${name}`} } // the collection name />
); } export default CollectionSelectItem;