import * as React from 'react'; import classNames from 'classnames'; import { StickerManagerPackRow } from './StickerManagerPackRow'; import { StickerPreviewModal } from './StickerPreviewModal'; import { LocalizerType } from '../../types/Util'; import { StickerPackType } from '../../state/ducks/stickers'; export type OwnProps = { readonly installedPacks: ReadonlyArray; readonly receivedPacks: ReadonlyArray; readonly blessedPacks: ReadonlyArray; readonly installStickerPack: (packId: string, packKey: string) => unknown; readonly uninstallStickerPack: (packId: string, packKey: string) => unknown; readonly i18n: LocalizerType; }; export type Props = OwnProps; export const StickerManager = React.memo( ({ installedPacks, receivedPacks, blessedPacks, installStickerPack, uninstallStickerPack, i18n, }: Props) => { const [ packToPreview, setPackToPreview, ] = React.useState(null); const clearPackToPreview = React.useCallback( () => { setPackToPreview(null); }, [setPackToPreview] ); const previewPack = React.useCallback( (pack: StickerPackType) => { setPackToPreview(pack); }, [clearPackToPreview] ); return ( <> {packToPreview ? ( ) : null}
{[ { i18nKey: 'stickers--StickerManager--InstalledPacks', i18nEmptyKey: 'stickers--StickerManager--InstalledPacks--Empty', packs: installedPacks, }, { i18nKey: 'stickers--StickerManager--BlessedPacks', i18nEmptyKey: 'stickers--StickerManager--BlessedPacks--Empty', packs: blessedPacks, }, { i18nKey: 'stickers--StickerManager--ReceivedPacks', i18nEmptyKey: 'stickers--StickerManager--ReceivedPacks--Empty', packs: receivedPacks, }, ].map(section => (

{i18n(section.i18nKey)}

{section.packs.length > 0 ? ( section.packs.map(pack => ( )) ) : (
{i18n(section.i18nEmptyKey)}
)}
))}
); } );