* WIP - adding expo * WIP - adding expo 2 * Fix tsc * Finish adding expo * Disable the 'require cycle' warning * Tweak plist * Modify some dependency versions to make expo happy * Fix icon fill * Get Web compiling for expo * 1.7 * Switch to react-navigation in expo2 (#287) * WIP Switch to react-navigation * WIP Switch to react-navigation 2 * WIP Switch to react-navigation 3 * Convert all screens to react navigation * Update BottomBar for react navigation * Update mobile menu to be react-native drawer * Fixes to drawer and bottombar * Factor out some helpers * Replace the navigation model with react-navigation * Restructure the shell folder and fix the header positioning * Restore the error boundary * Fix tsc * Implement not-found page * Remove react-native-gesture-handler (no longer used) * Handle notifee card presses * Handle all navigations from the state layer * Fix drawer behaviors * Fix two linking issues * Switch to our react-native-progress fork to fix an svg rendering issue * Get Web working with react-navigation * Refactor routes and navigation for a bit more clarity * Remove dead code * Rework Web shell to left/right nav to make this easier * Fix ViewHeader for desktop web * Hide profileheader back btn on desktop web * Move the compose button to the left nav * Implement reply prompt in threads for desktop web * Composer refactors * Factor out all platform-specific text input behaviors from the composer * Small fix * Update the web build to use tiptap for the composer * Tune up the mention autocomplete dropdown * Simplify the default avatar and banner * Fixes to link cards in web composer * Fix dropdowns on web * Tweak load latest on desktop * Add web beta message and feedback link * Fix up links in desktop web
177 lines
4.8 KiB
TypeScript
177 lines
4.8 KiB
TypeScript
import React from 'react'
|
|
import {StyleProp, StyleSheet, TextStyle, View, ViewStyle} from 'react-native'
|
|
import {Text} from '../text/Text'
|
|
import {Button, ButtonType} from './Button'
|
|
import {useTheme} from 'lib/ThemeContext'
|
|
import {choose} from 'lib/functions'
|
|
import {colors} from 'lib/styles'
|
|
|
|
export function ToggleButton({
|
|
type = 'default-light',
|
|
label,
|
|
isSelected,
|
|
style,
|
|
onPress,
|
|
}: {
|
|
type?: ButtonType
|
|
label: string
|
|
isSelected: boolean
|
|
style?: StyleProp<ViewStyle>
|
|
onPress: () => void
|
|
}) {
|
|
const theme = useTheme()
|
|
const circleStyle = choose<TextStyle, Record<ButtonType, TextStyle>>(type, {
|
|
primary: {
|
|
borderColor: theme.palette.primary.text,
|
|
},
|
|
secondary: {
|
|
borderColor: theme.palette.secondary.text,
|
|
},
|
|
inverted: {
|
|
borderColor: theme.palette.inverted.text,
|
|
},
|
|
'primary-outline': {
|
|
borderColor: theme.palette.primary.border,
|
|
},
|
|
'secondary-outline': {
|
|
borderColor: theme.palette.secondary.border,
|
|
},
|
|
'primary-light': {
|
|
borderColor: theme.palette.primary.border,
|
|
},
|
|
'secondary-light': {
|
|
borderColor: theme.palette.secondary.border,
|
|
},
|
|
default: {
|
|
borderColor: theme.palette.default.border,
|
|
},
|
|
'default-light': {
|
|
borderColor: theme.palette.default.border,
|
|
},
|
|
})
|
|
const circleFillStyle = choose<TextStyle, Record<ButtonType, TextStyle>>(
|
|
type,
|
|
{
|
|
primary: {
|
|
backgroundColor: theme.palette.primary.text,
|
|
opacity: isSelected ? 1 : 0.33,
|
|
},
|
|
secondary: {
|
|
backgroundColor: theme.palette.secondary.text,
|
|
opacity: isSelected ? 1 : 0.33,
|
|
},
|
|
inverted: {
|
|
backgroundColor: theme.palette.inverted.text,
|
|
opacity: isSelected ? 1 : 0.33,
|
|
},
|
|
'primary-outline': {
|
|
backgroundColor: theme.palette.primary.background,
|
|
opacity: isSelected ? 1 : 0.5,
|
|
},
|
|
'secondary-outline': {
|
|
backgroundColor: theme.palette.secondary.background,
|
|
opacity: isSelected ? 1 : 0.5,
|
|
},
|
|
'primary-light': {
|
|
backgroundColor: theme.palette.primary.background,
|
|
opacity: isSelected ? 1 : 0.5,
|
|
},
|
|
'secondary-light': {
|
|
backgroundColor: theme.palette.secondary.background,
|
|
opacity: isSelected ? 1 : 0.5,
|
|
},
|
|
default: {
|
|
backgroundColor: isSelected
|
|
? theme.palette.primary.background
|
|
: colors.gray3,
|
|
},
|
|
'default-light': {
|
|
backgroundColor: isSelected
|
|
? theme.palette.primary.background
|
|
: colors.gray3,
|
|
},
|
|
},
|
|
)
|
|
const labelStyle = choose<TextStyle, Record<ButtonType, TextStyle>>(type, {
|
|
primary: {
|
|
color: theme.palette.primary.text,
|
|
fontWeight: theme.palette.primary.isLowContrast ? '500' : undefined,
|
|
},
|
|
secondary: {
|
|
color: theme.palette.secondary.text,
|
|
fontWeight: theme.palette.secondary.isLowContrast ? '500' : undefined,
|
|
},
|
|
inverted: {
|
|
color: theme.palette.inverted.text,
|
|
fontWeight: theme.palette.inverted.isLowContrast ? '500' : undefined,
|
|
},
|
|
'primary-outline': {
|
|
color: theme.palette.primary.textInverted,
|
|
fontWeight: theme.palette.primary.isLowContrast ? '500' : undefined,
|
|
},
|
|
'secondary-outline': {
|
|
color: theme.palette.secondary.textInverted,
|
|
fontWeight: theme.palette.secondary.isLowContrast ? '500' : undefined,
|
|
},
|
|
'primary-light': {
|
|
color: theme.palette.primary.textInverted,
|
|
fontWeight: theme.palette.primary.isLowContrast ? '500' : undefined,
|
|
},
|
|
'secondary-light': {
|
|
color: theme.palette.secondary.textInverted,
|
|
fontWeight: theme.palette.secondary.isLowContrast ? '500' : undefined,
|
|
},
|
|
default: {
|
|
color: theme.palette.default.text,
|
|
fontWeight: theme.palette.default.isLowContrast ? '500' : undefined,
|
|
},
|
|
'default-light': {
|
|
color: theme.palette.default.text,
|
|
fontWeight: theme.palette.default.isLowContrast ? '500' : undefined,
|
|
},
|
|
})
|
|
return (
|
|
<Button type={type} onPress={onPress} style={style}>
|
|
<View style={styles.outer}>
|
|
<View style={[circleStyle, styles.circle]}>
|
|
<View
|
|
style={[
|
|
circleFillStyle,
|
|
styles.circleFill,
|
|
isSelected ? styles.circleFillSelected : undefined,
|
|
]}
|
|
/>
|
|
</View>
|
|
<Text type="button" style={[labelStyle, styles.label]}>
|
|
{label}
|
|
</Text>
|
|
</View>
|
|
</Button>
|
|
)
|
|
}
|
|
|
|
const styles = StyleSheet.create({
|
|
outer: {
|
|
flexDirection: 'row',
|
|
alignItems: 'center',
|
|
},
|
|
circle: {
|
|
width: 42,
|
|
height: 26,
|
|
borderRadius: 15,
|
|
padding: 4,
|
|
borderWidth: 1,
|
|
marginRight: 10,
|
|
},
|
|
circleFill: {
|
|
width: 16,
|
|
height: 16,
|
|
borderRadius: 10,
|
|
},
|
|
circleFillSelected: {
|
|
marginLeft: 16,
|
|
},
|
|
label: {
|
|
flex: 1,
|
|
},
|
|
})
|