about summary refs log tree commit diff
path: root/src/view/com/util/Selector.tsx
diff options
context:
space:
mode:
Diffstat (limited to 'src/view/com/util/Selector.tsx')
-rw-r--r--src/view/com/util/Selector.tsx73
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,
+  },
+})