forked from mihailShumilov/react-native-simple-emoji-picker
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.js
100 lines (90 loc) · 3.34 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
import React from 'react';
import {View, ScrollView, Text, TouchableOpacity} from 'react-native';
import PropTypes from 'prop-types';
import emoji from './data';
const EmojiItem = ({size, item, onPress}) => (
<TouchableOpacity style={{flex: 0, height: size, width: size}} onPress={onPress}>
<View style={{flex: 0, height: size, width: size}}>
<Text style={{flex: 0, fontSize: size / 4 * 3, paddingBottom: 2}}>
{item}
</Text>
</View>
</TouchableOpacity>
);
const EmojiCategory = ({headerStyle, emojiSize, name, items, onPick, showHeader}) => (
<View style={styles.category}>
{
showHeader &&
<Text style={{...styles.categoryName, ...headerStyle}}>{name}</Text>
}
<View style={styles.categoryItems}>
{items.map((em, idx) => (
<EmojiItem key={idx} size={emojiSize} onPress={() => onPick(em)} item={em}/>
))}
</View>
</View>
);
const EmojiPicker = ({headerStyle, containerHeight, containerBackgroundColor, emojiSize, onPick, emojiCategories, showHeader}) => (
<View style={{...styles.picker, height: containerHeight, backgroundColor: containerBackgroundColor}}>
<ScrollView horizontal={true} keyboardDismissMode="on-drag"
keyboardShouldPersistTaps={'always'}>
{
emoji.map((category, idx) => {
return (
(emojiCategories.indexOf(category.category) >= 0) &&
<EmojiCategory
key={idx}
headerStyle={headerStyle}
emojiSize={emojiSize}
name={category.category}
items={category.items}
onPick={onPick}
showHeader={showHeader}
/>
)
;
}
)
}
</ScrollView>
</View>
);
EmojiPicker.propTypes = {
onPick : PropTypes.func,
headerStyle : PropTypes.object,
containerHeight : PropTypes.number.isRequired,
containerBackgroundColor: PropTypes.string.isRequired,
emojiSize : PropTypes.number.isRequired,
emojiCategories : PropTypes.array,
showHeader : PropTypes.bool
};
EmojiPicker.defaultProps = {
containerHeight : 240,
containerBackgroundColor: 'rgba(0, 0, 0, 0.1)',
emojiSize : 40,
emojiCategories : ['People', 'Nature', 'Foods', 'Activity', 'Places', 'Objects', 'Symbols', 'Flags'],
showHeader : true
};
const styles = {
picker : {
flex : 0,
},
category : {
flex : 0,
paddingHorizontal: 14,
paddingTop : 2,
marginLeft : 2,
paddingLeft : 0
},
categoryName : {
paddingVertical : 8,
paddingHorizontal: 4,
fontSize : 12,
color : "#888",
},
categoryItems: {
flex : 1,
flexWrap: 'wrap',
},
};
export default EmojiPicker;