aboutsummaryrefslogtreecommitdiff
path: root/src/components/profile/Cover.tsx
blob: 3c0f7045df51d799e3d9e39f087bb8ab01fd6945 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
import React, {useContext} from 'react';
import {Image, StyleSheet} from 'react-native';
import Animated from 'react-native-reanimated';
import {IMAGE_WIDTH, COVER_HEIGHT, IMAGE_HEIGHT} from '../../constants';
import {useSelector, useStore} from 'react-redux';
import {RootState} from '../../store/rootreducer';
import {ScreenType} from '../../types';
import {DUMMY_USERID, NO_USER_DATA} from '../../store/initialStates';

const {interpolate, Extrapolate} = Animated;
interface CoverProps {
  y: Animated.Value<number>;
  userXId: string;
  screenType: ScreenType;
}
const Cover: React.FC<CoverProps> = ({y, userXId, screenType}) => {
  const {cover = ''} = userXId
    ? useSelector((state: RootState) => state.userX[screenType][userXId])
    : useSelector((state: RootState) => state.user);

  const scale: Animated.Node<number> = interpolate(y, {
    inputRange: [-COVER_HEIGHT, 0],
    outputRange: [1.5, 1.25],
    extrapolateRight: Extrapolate.CLAMP,
  });
  return (
    <Animated.View style={[styles.container, {transform: [{scale}]}]}>
      <Image
        style={styles.image}
        source={
          cover
            ? {uri: cover}
            : require('../../assets/images/cover-placeholder.png')
        }
      />
    </Animated.View>
  );
};

const styles = StyleSheet.create({
  container: {
    position: 'absolute',
  },
  image: {
    width: IMAGE_WIDTH,
    height: IMAGE_HEIGHT,
  },
});
export default Cover;