-
Notifications
You must be signed in to change notification settings - Fork 0
/
index.js
executable file
·119 lines (112 loc) · 5.72 KB
/
index.js
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
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
// @flow
import * as React from 'react';
import {
TouchableOpacity,
Text,
Image,
StyleSheet,
} from 'react-native';
type Props = {
root: React.Ref,
refView: string,
visible: boolean,
type: string,
icon: React.Element,
right: number,
bottom: number,
width: number,
height: number,
radius: boolean,
borderRadius: number,
backgroundColor: string,
text: string,
fontSize: number,
color: string,
customTextStyle: Object,
image: Object,
customImageStyle: Object,
};
const scrollUpImage = '';
const styles = StyleSheet.create({
wrapper: {
position: 'absolute',
flex: 1,
justifyContent: 'center',
alignItems: 'center',
},
});
export default class ScrollUp extends React.Component<Props> {
static defaultProps = {
visible: true,
radius: true,
backgroundColor: 'transparent',
width: 40,
height: 40,
color: '#fff',
fontSize: 12,
icon: null,
right: 30,
bottom: 30,
borderRadius: 50,
text: 'Scroll Up',
image: { uri: scrollUpImage },
customTextStyle: {},
customImageStyle: {},
};
handleOnPress = () => {
if (this.props.refView === 'ListView' || this.props.refView === 'ScrollView') {
this.props.root.scrollTo({ x: 0, y: 0, animated: true });
}
if (this.props.refView === 'FlatList') {
this.props.root.scrollToOffset({ offset: 0, animated: true });
}
if (this.props.refView === 'SectionList') {
this.props.root.scrollToLocation({ itemIndex: 0, sectionIndex: 0 });
}
}
render() {
if (!this.props.visible) return null;
return (
<TouchableOpacity
onPress={() => this.handleOnPress()}
style={[
styles.wrapper,
{
width: this.props.width,
height: this.props.height,
right: this.props.right,
bottom: this.props.bottom,
backgroundColor: this.props.backgroundColor,
borderRadius: this.props.radius ? this.props.borderRadius : 0,
},
]}
>
{this.props.type === 'icon' && { ...this.props.icon }}
{this.props.type === 'text' &&
<Text
style={[
{
textAlign: 'center',
color: this.props.color,
fontSize: this.props.fontSize,
},
this.props.customTextStyle,
]}
>
{this.props.text}
</Text>}
{this.props.type === 'image' &&
<Image
style={[
{
width: this.props.width,
height: this.props.height,
},
this.props.customImageStyle,
]}
source={this.props.image}
/>}
</TouchableOpacity>
);
}
}