diff options
author | Paul Frazee <pfrazee@gmail.com> | 2022-09-05 16:57:20 -0500 |
---|---|---|
committer | Paul Frazee <pfrazee@gmail.com> | 2022-09-05 16:57:20 -0500 |
commit | 2ec09ba54574f5e05f0bbec9c864dacd2092edd4 (patch) | |
tree | dfa5960c0ede277260ddb6456523033ea4226ff9 /src/view/com/util/Selector.tsx | |
parent | cb310ab1c1e4d2beb6f39b39e4972b9ae21f9849 (diff) | |
download | voidsky-2ec09ba54574f5e05f0bbec9c864dacd2092edd4.tar.zst |
Rework profile header
Diffstat (limited to 'src/view/com/util/Selector.tsx')
-rw-r--r-- | src/view/com/util/Selector.tsx | 73 |
1 files changed, 73 insertions, 0 deletions
diff --git a/src/view/com/util/Selector.tsx b/src/view/com/util/Selector.tsx new file mode 100644 index 000000000..ef7c65d59 --- /dev/null +++ b/src/view/com/util/Selector.tsx @@ -0,0 +1,73 @@ +import React, {useState} from 'react' +import { + StyleProp, + StyleSheet, + Text, + TouchableWithoutFeedback, + View, + ViewStyle, +} from 'react-native' +import {colors} from '../../lib/styles' + +export interface SelectorItem { + label: string +} + +export function Selector({ + style, + items, + onSelect, +}: { + style?: StyleProp<ViewStyle> + items: SelectorItem[] + onSelect?: (index: number) => void +}) { + const [selectedIndex, setSelectedIndex] = useState<number>(0) + const onPressItem = (index: number) => { + setSelectedIndex(index) + onSelect?.(index) + } + + return ( + <View style={[styles.outer, style]}> + {items.map((item, i) => { + const selected = i === selectedIndex + return ( + <TouchableWithoutFeedback key={i} onPress={() => onPressItem(i)}> + <View style={selected ? styles.itemSelected : styles.item}> + <Text style={selected ? styles.labelSelected : styles.label}> + {item.label} + </Text> + </View> + </TouchableWithoutFeedback> + ) + })} + </View> + ) +} + +const styles = StyleSheet.create({ + outer: { + flexDirection: 'row', + paddingHorizontal: 14, + }, + item: { + paddingBottom: 12, + marginRight: 20, + }, + label: { + fontWeight: '600', + fontSize: 16, + color: colors.gray5, + }, + itemSelected: { + paddingBottom: 8, + marginRight: 20, + borderBottomWidth: 4, + borderBottomColor: colors.purple3, + }, + labelSelected: { + fontWeight: '600', + fontSize: 16, + }, +}) |