1f94354caSBartłomiej Bukowskiimport { useCallback } from 'react';
2f94354caSBartłomiej Bukowskiimport { View, TouchableOpacity, Text, StyleSheet } from 'react-native';
3f94354caSBartłomiej Bukowski
4f94354caSBartłomiej Bukowskiimport { ActionFunction } from './index.types';
5*8a424bebSJames Ideimport Colors from '../../constants/Colors';
6f94354caSBartłomiej Bukowski
7f94354caSBartłomiej Bukowskiexport default function ActionButton({
8f94354caSBartłomiej Bukowski  name,
9f94354caSBartłomiej Bukowski  action,
10f94354caSBartłomiej Bukowski  onPress,
11f94354caSBartłomiej Bukowski}: {
12f94354caSBartłomiej Bukowski  name: string;
13f94354caSBartłomiej Bukowski  action: ActionFunction;
14f94354caSBartłomiej Bukowski  onPress: (action: ActionFunction) => void;
15f94354caSBartłomiej Bukowski}) {
16f94354caSBartłomiej Bukowski  const handlePress = useCallback(() => onPress(action), [onPress, action]);
17f94354caSBartłomiej Bukowski
18f94354caSBartłomiej Bukowski  return (
19f94354caSBartłomiej Bukowski    <View style={styles.button}>
20f94354caSBartłomiej Bukowski      <TouchableOpacity onPress={handlePress}>
21f94354caSBartłomiej Bukowski        <Text style={styles.buttonText}>{name}</Text>
22f94354caSBartłomiej Bukowski      </TouchableOpacity>
23f94354caSBartłomiej Bukowski    </View>
24f94354caSBartłomiej Bukowski  );
25f94354caSBartłomiej Bukowski}
26f94354caSBartłomiej Bukowski
27f94354caSBartłomiej Bukowskiconst styles = StyleSheet.create({
28f94354caSBartłomiej Bukowski  button: {
29f94354caSBartłomiej Bukowski    paddingVertical: 3,
30f94354caSBartłomiej Bukowski    paddingHorizontal: 6,
31f94354caSBartłomiej Bukowski    marginLeft: 5,
32f94354caSBartłomiej Bukowski    backgroundColor: Colors.tintColor,
33f94354caSBartłomiej Bukowski    borderRadius: 5,
34f94354caSBartłomiej Bukowski  },
35f94354caSBartłomiej Bukowski  buttonText: {
36f94354caSBartłomiej Bukowski    fontSize: 10,
37f94354caSBartłomiej Bukowski    padding: 2,
38f94354caSBartłomiej Bukowski    fontWeight: '500',
39f94354caSBartłomiej Bukowski    color: 'white',
40f94354caSBartłomiej Bukowski  },
41f94354caSBartłomiej Bukowski});
42