// Copyright 2019 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import * as React from 'react'; import { ConfirmationDialog } from '../ConfirmationDialog'; import type { LocalizerType } from '../../types/Util'; import type { StickerPackType } from '../../state/ducks/stickers'; import { Button, ButtonVariant } from '../Button'; import { UserText } from '../UserText'; export type OwnProps = { readonly i18n: LocalizerType; readonly pack: StickerPackType; readonly onClickPreview?: (sticker: StickerPackType) => unknown; readonly installStickerPack?: (packId: string, packKey: string) => unknown; readonly uninstallStickerPack?: (packId: string, packKey: string) => unknown; }; export type Props = OwnProps; export const StickerManagerPackRow = React.memo( function StickerManagerPackRowInner({ installStickerPack, uninstallStickerPack, onClickPreview, pack, i18n, }: Props) { const { id, key, isBlessed } = pack; const [uninstalling, setUninstalling] = React.useState(false); const clearUninstalling = React.useCallback(() => { setUninstalling(false); }, [setUninstalling]); const handleInstall = React.useCallback( (e: React.MouseEvent) => { e.stopPropagation(); if (installStickerPack) { installStickerPack(id, key); } }, [id, installStickerPack, key] ); const handleUninstall = React.useCallback( (e: React.MouseEvent) => { e.stopPropagation(); if (isBlessed && uninstallStickerPack) { uninstallStickerPack(id, key); } else { setUninstalling(true); } }, [id, isBlessed, key, setUninstalling, uninstallStickerPack] ); const handleConfirmUninstall = React.useCallback(() => { clearUninstalling(); if (uninstallStickerPack) { uninstallStickerPack(id, key); } }, [id, key, clearUninstalling, uninstallStickerPack]); const handleKeyDown = React.useCallback( (event: React.KeyboardEvent) => { if ( onClickPreview && (event.key === 'Enter' || event.key === 'Space') ) { event.stopPropagation(); event.preventDefault(); onClickPreview(pack); } }, [onClickPreview, pack] ); const handleClickPreview = React.useCallback( (event: React.MouseEvent) => { if (onClickPreview) { event.stopPropagation(); event.preventDefault(); onClickPreview(pack); } }, [onClickPreview, pack] ); return ( <> {uninstalling ? ( {i18n('icu:stickers--StickerManager--UninstallWarning')} ) : null}
{pack.cover ? ( {pack.title} ) : (
)}
{pack.isBlessed ? ( ) : null}
{pack.author}
{pack.status === 'installed' ? ( ) : ( )}
); } );