2019-05-16 22:32:11 +00:00
|
|
|
import { connect } from 'react-redux';
|
|
|
|
import { mapDispatchToProps } from '../actions';
|
|
|
|
import { StickerPreviewModal } from '../../components/stickers/StickerPreviewModal';
|
|
|
|
import { StateType } from '../reducer';
|
|
|
|
|
2019-05-24 01:27:42 +00:00
|
|
|
import { getIntl, getStickersPath, getTempPath } from '../selectors/user';
|
2019-05-16 22:32:11 +00:00
|
|
|
import {
|
|
|
|
getBlessedPacks,
|
|
|
|
getPacks,
|
|
|
|
translatePackFromDB,
|
|
|
|
} from '../selectors/stickers';
|
|
|
|
|
|
|
|
type ExternalProps = {
|
|
|
|
packId: string;
|
|
|
|
readonly onClose: () => unknown;
|
|
|
|
};
|
|
|
|
|
|
|
|
const mapStateToProps = (state: StateType, props: ExternalProps) => {
|
|
|
|
const { packId } = props;
|
|
|
|
const stickersPath = getStickersPath(state);
|
2019-05-24 01:27:42 +00:00
|
|
|
const tempPath = getTempPath(state);
|
|
|
|
|
2019-05-16 22:32:11 +00:00
|
|
|
const packs = getPacks(state);
|
|
|
|
const blessedPacks = getBlessedPacks(state);
|
|
|
|
const pack = packs[packId];
|
|
|
|
|
|
|
|
return {
|
|
|
|
...props,
|
2019-05-24 01:27:42 +00:00
|
|
|
pack: pack
|
|
|
|
? translatePackFromDB(pack, packs, blessedPacks, stickersPath, tempPath)
|
|
|
|
: undefined,
|
2019-05-16 22:32:11 +00:00
|
|
|
i18n: getIntl(state),
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
const smart = connect(mapStateToProps, mapDispatchToProps);
|
|
|
|
|
|
|
|
export const SmartStickerPreviewModal = smart(StickerPreviewModal);
|