@retray-dev/ui-kit 2.7.0 → 3.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/COMPONENTS.md +102 -15
- package/README.md +25 -5
- package/dist/index.d.mts +36 -6
- package/dist/index.d.ts +36 -6
- package/dist/index.js +692 -484
- package/dist/index.mjs +622 -415
- package/package.json +6 -3
- package/src/assets/fonts/Poppins-Black.ttf +0 -0
- package/src/assets/fonts/Poppins-BlackItalic.ttf +0 -0
- package/src/assets/fonts/Poppins-Bold.ttf +0 -0
- package/src/assets/fonts/Poppins-BoldItalic.ttf +0 -0
- package/src/assets/fonts/Poppins-ExtraBold.ttf +0 -0
- package/src/assets/fonts/Poppins-ExtraBoldItalic.ttf +0 -0
- package/src/assets/fonts/Poppins-ExtraLight.ttf +0 -0
- package/src/assets/fonts/Poppins-ExtraLightItalic.ttf +0 -0
- package/src/assets/fonts/Poppins-Italic.ttf +0 -0
- package/src/assets/fonts/Poppins-Light.ttf +0 -0
- package/src/assets/fonts/Poppins-LightItalic.ttf +0 -0
- package/src/assets/fonts/Poppins-Medium.ttf +0 -0
- package/src/assets/fonts/Poppins-MediumItalic.ttf +0 -0
- package/src/assets/fonts/Poppins-Regular.ttf +0 -0
- package/src/assets/fonts/Poppins-SemiBold.ttf +0 -0
- package/src/assets/fonts/Poppins-SemiBoldItalic.ttf +0 -0
- package/src/assets/fonts/Poppins-Thin.ttf +0 -0
- package/src/assets/fonts/Poppins-ThinItalic.ttf +0 -0
- package/src/components/Accordion/Accordion.tsx +16 -9
- package/src/components/AlertBanner/AlertBanner.tsx +35 -35
- package/src/components/Avatar/Avatar.tsx +1 -1
- package/src/components/Badge/Badge.tsx +12 -8
- package/src/components/Button/Button.tsx +9 -9
- package/src/components/Card/Card.tsx +12 -9
- package/src/components/Checkbox/Checkbox.tsx +9 -8
- package/src/components/Chip/Chip.tsx +22 -6
- package/src/components/ConfirmDialog/ConfirmDialog.tsx +86 -38
- package/src/components/CurrencyDisplay/CurrencyDisplay.tsx +1 -1
- package/src/components/CurrencyInput/CurrencyInput.tsx +11 -4
- package/src/components/EmptyState/EmptyState.tsx +2 -1
- package/src/components/IconButton/IconButton.tsx +147 -0
- package/src/components/IconButton/index.ts +2 -0
- package/src/components/Input/Input.tsx +12 -8
- package/src/components/LabelValue/LabelValue.tsx +4 -3
- package/src/components/ListItem/ListItem.tsx +10 -9
- package/src/components/MonthPicker/MonthPicker.tsx +1 -1
- package/src/components/RadioGroup/RadioGroup.tsx +36 -35
- package/src/components/Select/Select.tsx +19 -21
- package/src/components/Sheet/Sheet.tsx +4 -3
- package/src/components/Slider/Slider.tsx +3 -3
- package/src/components/Spinner/Spinner.tsx +36 -2
- package/src/components/Switch/Switch.tsx +4 -4
- package/src/components/Tabs/Tabs.tsx +10 -16
- package/src/components/Text/Text.tsx +6 -6
- package/src/components/Textarea/Textarea.tsx +8 -6
- package/src/components/Toast/Toast.tsx +29 -23
- package/src/components/Toggle/Toggle.tsx +7 -5
- package/src/fonts.ts +30 -0
- package/src/index.ts +1 -0
- package/src/theme/colors.ts +22 -14
- package/src/theme/types.ts +4 -0
- package/src/components/Alert/Alert.tsx +0 -84
|
@@ -1,5 +1,13 @@
|
|
|
1
|
-
import React from 'react'
|
|
2
|
-
import {
|
|
1
|
+
import React, { useEffect, useRef } from 'react'
|
|
2
|
+
import { View, Text, StyleSheet } from 'react-native'
|
|
3
|
+
import {
|
|
4
|
+
BottomSheetModal,
|
|
5
|
+
BottomSheetView,
|
|
6
|
+
BottomSheetBackdrop,
|
|
7
|
+
type BottomSheetBackdropProps,
|
|
8
|
+
} from '@gorhom/bottom-sheet'
|
|
9
|
+
import { Feather } from '@expo/vector-icons'
|
|
10
|
+
import { impactLight } from '../../utils/haptics'
|
|
3
11
|
import { useTheme } from '../../theme'
|
|
4
12
|
import { Button } from '../Button'
|
|
5
13
|
import { s, vs, ms, mvs } from '../../utils/scaling'
|
|
@@ -26,58 +34,98 @@ export function ConfirmDialog({
|
|
|
26
34
|
onCancel,
|
|
27
35
|
}: ConfirmDialogProps) {
|
|
28
36
|
const { colors } = useTheme()
|
|
37
|
+
const ref = useRef<BottomSheetModal>(null)
|
|
38
|
+
|
|
39
|
+
useEffect(() => {
|
|
40
|
+
if (visible) {
|
|
41
|
+
impactLight()
|
|
42
|
+
ref.current?.present()
|
|
43
|
+
} else {
|
|
44
|
+
ref.current?.dismiss()
|
|
45
|
+
}
|
|
46
|
+
}, [visible])
|
|
47
|
+
|
|
48
|
+
const renderBackdrop = (props: BottomSheetBackdropProps) => (
|
|
49
|
+
<BottomSheetBackdrop
|
|
50
|
+
{...props}
|
|
51
|
+
disappearsOnIndex={-1}
|
|
52
|
+
appearsOnIndex={0}
|
|
53
|
+
pressBehavior="close"
|
|
54
|
+
/>
|
|
55
|
+
)
|
|
29
56
|
|
|
30
57
|
return (
|
|
31
|
-
<
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
58
|
+
<BottomSheetModal
|
|
59
|
+
ref={ref}
|
|
60
|
+
snapPoints={['35%']}
|
|
61
|
+
onDismiss={onCancel}
|
|
62
|
+
backdropComponent={renderBackdrop}
|
|
63
|
+
backgroundStyle={[styles.background, { backgroundColor: colors.card }]}
|
|
64
|
+
handleIndicatorStyle={[styles.handle, { backgroundColor: colors.border }]}
|
|
65
|
+
enablePanDownToClose
|
|
66
|
+
>
|
|
67
|
+
<BottomSheetView style={styles.content}>
|
|
68
|
+
<Text style={[styles.title, { color: colors.cardForeground }]} allowFontScaling={true}>
|
|
69
|
+
{title}
|
|
70
|
+
</Text>
|
|
71
|
+
{description ? (
|
|
72
|
+
<Text style={[styles.description, { color: colors.mutedForeground }]} allowFontScaling={true}>
|
|
73
|
+
{description}
|
|
39
74
|
</Text>
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
<
|
|
48
|
-
|
|
75
|
+
) : null}
|
|
76
|
+
<View style={styles.actions}>
|
|
77
|
+
<Button
|
|
78
|
+
label={cancelLabel}
|
|
79
|
+
variant="outline"
|
|
80
|
+
fullWidth
|
|
81
|
+
onPress={onCancel}
|
|
82
|
+
icon={<Feather name="x" size={15} color={colors.foreground} />}
|
|
83
|
+
/>
|
|
84
|
+
<Button
|
|
85
|
+
label={confirmLabel}
|
|
86
|
+
variant={confirmVariant}
|
|
87
|
+
fullWidth
|
|
88
|
+
onPress={onConfirm}
|
|
89
|
+
icon={
|
|
90
|
+
<Feather
|
|
91
|
+
name={confirmVariant === 'destructive' ? 'trash-2' : 'check'}
|
|
92
|
+
size={15}
|
|
93
|
+
color={
|
|
94
|
+
confirmVariant === 'destructive'
|
|
95
|
+
? colors.destructiveForeground
|
|
96
|
+
: colors.primaryForeground
|
|
97
|
+
}
|
|
98
|
+
/>
|
|
99
|
+
}
|
|
100
|
+
/>
|
|
49
101
|
</View>
|
|
50
|
-
</
|
|
51
|
-
</
|
|
102
|
+
</BottomSheetView>
|
|
103
|
+
</BottomSheetModal>
|
|
52
104
|
)
|
|
53
105
|
}
|
|
54
106
|
|
|
55
107
|
const styles = StyleSheet.create({
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
108
|
+
background: {
|
|
109
|
+
borderTopLeftRadius: ms(16),
|
|
110
|
+
borderTopRightRadius: ms(16),
|
|
111
|
+
},
|
|
112
|
+
handle: {
|
|
113
|
+
width: s(36),
|
|
114
|
+
height: vs(4),
|
|
115
|
+
borderRadius: ms(2),
|
|
62
116
|
},
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
borderRadius: ms(16),
|
|
67
|
-
padding: s(24),
|
|
117
|
+
content: {
|
|
118
|
+
paddingHorizontal: s(24),
|
|
119
|
+
paddingBottom: vs(32),
|
|
68
120
|
gap: vs(12),
|
|
69
|
-
shadowColor: '#000',
|
|
70
|
-
shadowOffset: { width: 0, height: 8 },
|
|
71
|
-
shadowOpacity: 0.15,
|
|
72
|
-
shadowRadius: 16,
|
|
73
|
-
elevation: 8,
|
|
74
121
|
},
|
|
75
122
|
title: {
|
|
123
|
+
fontFamily: 'Poppins-SemiBold',
|
|
76
124
|
fontSize: ms(18),
|
|
77
|
-
fontWeight: '600',
|
|
78
125
|
lineHeight: mvs(26),
|
|
79
126
|
},
|
|
80
127
|
description: {
|
|
128
|
+
fontFamily: 'Poppins-Regular',
|
|
81
129
|
fontSize: ms(15),
|
|
82
130
|
lineHeight: mvs(22),
|
|
83
131
|
},
|
|
@@ -20,6 +20,8 @@ export interface CurrencyInputProps {
|
|
|
20
20
|
hint?: string
|
|
21
21
|
placeholder?: string
|
|
22
22
|
editable?: boolean
|
|
23
|
+
/** Icon or element rendered at the left edge inside the input field. */
|
|
24
|
+
prefixIcon?: React.ReactNode
|
|
23
25
|
containerStyle?: ViewStyle
|
|
24
26
|
style?: TextStyle
|
|
25
27
|
}
|
|
@@ -42,31 +44,36 @@ export function CurrencyInput({
|
|
|
42
44
|
hint,
|
|
43
45
|
placeholder,
|
|
44
46
|
editable,
|
|
47
|
+
prefixIcon,
|
|
45
48
|
containerStyle,
|
|
46
49
|
style,
|
|
47
50
|
}: CurrencyInputProps) {
|
|
48
51
|
const handleChange = (text: string) => {
|
|
49
52
|
const withoutPrefix = prefix && text.startsWith(prefix) ? text.slice(prefix.length) : text
|
|
50
53
|
const formatted = formatCurrency(withoutPrefix, thousandsSeparator)
|
|
51
|
-
const display = formatted
|
|
54
|
+
const display = formatted
|
|
52
55
|
onChangeText?.(display)
|
|
53
56
|
const separatorRegex = new RegExp(`\\${thousandsSeparator}`, 'g')
|
|
54
57
|
const raw = parseFloat(formatted.replace(separatorRegex, '') || '0')
|
|
55
58
|
onChangeValue?.(isNaN(raw) ? 0 : raw)
|
|
56
59
|
}
|
|
57
60
|
|
|
58
|
-
const inputStyle: TextStyle = size === 'large' ? { fontSize: ms(36) } : {}
|
|
61
|
+
const inputStyle: TextStyle = size === 'large' ? { fontFamily: 'Poppins-Regular', fontSize: ms(36) } : { fontFamily: 'Poppins-Regular' }
|
|
62
|
+
|
|
63
|
+
// Remove prefix from display value if present
|
|
64
|
+
const displayValue = value && prefix && value.startsWith(prefix) ? value.slice(prefix.length) : value
|
|
59
65
|
|
|
60
66
|
return (
|
|
61
67
|
<Input
|
|
62
|
-
value={
|
|
68
|
+
value={displayValue}
|
|
63
69
|
onChangeText={handleChange}
|
|
64
70
|
keyboardType="numeric"
|
|
65
71
|
label={label}
|
|
66
72
|
error={error}
|
|
67
73
|
hint={hint}
|
|
68
|
-
placeholder={placeholder ??
|
|
74
|
+
placeholder={placeholder ?? '0'}
|
|
69
75
|
editable={editable}
|
|
76
|
+
prefix={prefixIcon}
|
|
70
77
|
containerStyle={containerStyle}
|
|
71
78
|
style={[inputStyle, style]}
|
|
72
79
|
/>
|
|
@@ -97,14 +97,15 @@ const styles = StyleSheet.create({
|
|
|
97
97
|
maxWidth: s(320),
|
|
98
98
|
},
|
|
99
99
|
title: {
|
|
100
|
+
fontFamily: 'Poppins-Medium',
|
|
100
101
|
fontSize: ms(18),
|
|
101
|
-
fontWeight: '500',
|
|
102
102
|
textAlign: 'center',
|
|
103
103
|
},
|
|
104
104
|
titleCompact: {
|
|
105
105
|
fontSize: ms(15),
|
|
106
106
|
},
|
|
107
107
|
description: {
|
|
108
|
+
fontFamily: 'Poppins-Regular',
|
|
108
109
|
fontSize: ms(14),
|
|
109
110
|
lineHeight: mvs(20),
|
|
110
111
|
textAlign: 'center',
|
|
@@ -0,0 +1,147 @@
|
|
|
1
|
+
import React, { useRef } from 'react'
|
|
2
|
+
import {
|
|
3
|
+
TouchableOpacity,
|
|
4
|
+
Animated,
|
|
5
|
+
ActivityIndicator,
|
|
6
|
+
StyleSheet,
|
|
7
|
+
TouchableOpacityProps,
|
|
8
|
+
ViewStyle,
|
|
9
|
+
Platform,
|
|
10
|
+
} from 'react-native'
|
|
11
|
+
|
|
12
|
+
const nativeDriver = Platform.OS !== 'web'
|
|
13
|
+
import { impactLight } from '../../utils/haptics'
|
|
14
|
+
import { useTheme } from '../../theme'
|
|
15
|
+
import { s } from '../../utils/scaling'
|
|
16
|
+
import { renderIcon } from '../../utils/icons'
|
|
17
|
+
|
|
18
|
+
export type IconButtonVariant = 'primary' | 'secondary' | 'outline' | 'ghost' | 'destructive'
|
|
19
|
+
export type IconButtonSize = 'sm' | 'md' | 'lg'
|
|
20
|
+
|
|
21
|
+
export interface IconButtonProps extends TouchableOpacityProps {
|
|
22
|
+
/**
|
|
23
|
+
* Icon name from `@expo/vector-icons` (e.g. `"home"`, `"star"`, `"plus"`).
|
|
24
|
+
* See https://icons.expo.fyi. Takes precedence over `icon` when both supplied.
|
|
25
|
+
*/
|
|
26
|
+
iconName?: string
|
|
27
|
+
/** ReactNode icon — used when `iconName` is not provided. */
|
|
28
|
+
icon?: React.ReactNode
|
|
29
|
+
/** Override the resolved icon color. Defaults to the foreground color for the active variant. */
|
|
30
|
+
iconColor?: string
|
|
31
|
+
variant?: IconButtonVariant
|
|
32
|
+
size?: IconButtonSize
|
|
33
|
+
/** Replaces icon with a spinner and forces `disabled`. */
|
|
34
|
+
loading?: boolean
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
const sizeMap: Record<IconButtonSize, { container: number; icon: number }> = {
|
|
38
|
+
sm: { container: s(40), icon: 18 },
|
|
39
|
+
md: { container: s(44), icon: 20 },
|
|
40
|
+
lg: { container: s(52), icon: 24 },
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
export function IconButton({
|
|
44
|
+
iconName,
|
|
45
|
+
icon,
|
|
46
|
+
iconColor,
|
|
47
|
+
variant = 'primary',
|
|
48
|
+
size = 'md',
|
|
49
|
+
loading = false,
|
|
50
|
+
disabled,
|
|
51
|
+
style,
|
|
52
|
+
onPress,
|
|
53
|
+
...props
|
|
54
|
+
}: IconButtonProps) {
|
|
55
|
+
const { colors } = useTheme()
|
|
56
|
+
const isDisabled = disabled || loading
|
|
57
|
+
const scale = useRef(new Animated.Value(1)).current
|
|
58
|
+
|
|
59
|
+
const handlePressIn = () => {
|
|
60
|
+
if (isDisabled) return
|
|
61
|
+
Animated.spring(scale, {
|
|
62
|
+
toValue: 0.95,
|
|
63
|
+
useNativeDriver: nativeDriver,
|
|
64
|
+
speed: 40,
|
|
65
|
+
bounciness: 0,
|
|
66
|
+
}).start()
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
const handlePressOut = () => {
|
|
70
|
+
Animated.spring(scale, {
|
|
71
|
+
toValue: 1,
|
|
72
|
+
useNativeDriver: nativeDriver,
|
|
73
|
+
speed: 40,
|
|
74
|
+
bounciness: 4,
|
|
75
|
+
}).start()
|
|
76
|
+
}
|
|
77
|
+
|
|
78
|
+
const handlePress: TouchableOpacityProps['onPress'] = (e) => {
|
|
79
|
+
impactLight()
|
|
80
|
+
onPress?.(e)
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
const containerVariantStyle: ViewStyle = {
|
|
84
|
+
primary: { backgroundColor: colors.primary },
|
|
85
|
+
secondary: { backgroundColor: colors.secondary },
|
|
86
|
+
outline: { backgroundColor: 'transparent', borderWidth: 1.5, borderColor: colors.border },
|
|
87
|
+
ghost: { backgroundColor: 'transparent' },
|
|
88
|
+
destructive: { backgroundColor: colors.destructive },
|
|
89
|
+
}[variant]
|
|
90
|
+
|
|
91
|
+
const defaultIconColor: string = {
|
|
92
|
+
primary: colors.primaryForeground,
|
|
93
|
+
secondary: colors.secondaryForeground,
|
|
94
|
+
outline: colors.foreground,
|
|
95
|
+
ghost: colors.foreground,
|
|
96
|
+
destructive: colors.destructiveForeground,
|
|
97
|
+
}[variant]
|
|
98
|
+
|
|
99
|
+
const spinnerColor =
|
|
100
|
+
variant === 'destructive' ? colors.destructiveForeground
|
|
101
|
+
: variant === 'primary' || variant === 'secondary' ? colors.primaryForeground
|
|
102
|
+
: colors.foreground
|
|
103
|
+
|
|
104
|
+
const { container: containerSize, icon: iconSize } = sizeMap[size]
|
|
105
|
+
|
|
106
|
+
const resolvedIcon: React.ReactNode = iconName
|
|
107
|
+
? renderIcon(iconName, iconSize, iconColor ?? defaultIconColor)
|
|
108
|
+
: icon
|
|
109
|
+
|
|
110
|
+
return (
|
|
111
|
+
<Animated.View style={{ transform: [{ scale }] }}>
|
|
112
|
+
<TouchableOpacity
|
|
113
|
+
style={[
|
|
114
|
+
styles.base,
|
|
115
|
+
containerVariantStyle,
|
|
116
|
+
{ width: containerSize, height: containerSize },
|
|
117
|
+
isDisabled && styles.disabled,
|
|
118
|
+
style,
|
|
119
|
+
]}
|
|
120
|
+
disabled={isDisabled}
|
|
121
|
+
activeOpacity={1}
|
|
122
|
+
touchSoundDisabled={true}
|
|
123
|
+
onPress={handlePress}
|
|
124
|
+
onPressIn={handlePressIn}
|
|
125
|
+
onPressOut={handlePressOut}
|
|
126
|
+
{...props}
|
|
127
|
+
>
|
|
128
|
+
{loading ? (
|
|
129
|
+
<ActivityIndicator size="small" color={spinnerColor} />
|
|
130
|
+
) : (
|
|
131
|
+
resolvedIcon
|
|
132
|
+
)}
|
|
133
|
+
</TouchableOpacity>
|
|
134
|
+
</Animated.View>
|
|
135
|
+
)
|
|
136
|
+
}
|
|
137
|
+
|
|
138
|
+
const styles = StyleSheet.create({
|
|
139
|
+
base: {
|
|
140
|
+
borderRadius: 999,
|
|
141
|
+
alignItems: 'center',
|
|
142
|
+
justifyContent: 'center',
|
|
143
|
+
},
|
|
144
|
+
disabled: {
|
|
145
|
+
opacity: 0.5,
|
|
146
|
+
},
|
|
147
|
+
})
|
|
@@ -137,40 +137,44 @@ const styles = StyleSheet.create({
|
|
|
137
137
|
gap: vs(8),
|
|
138
138
|
},
|
|
139
139
|
label: {
|
|
140
|
-
|
|
141
|
-
|
|
140
|
+
fontFamily: 'Poppins-Medium',
|
|
141
|
+
fontSize: ms(13),
|
|
142
142
|
},
|
|
143
143
|
inputWrapper: {
|
|
144
144
|
flexDirection: 'row',
|
|
145
145
|
alignItems: 'center',
|
|
146
|
-
borderWidth: 1
|
|
146
|
+
borderWidth: 1,
|
|
147
147
|
borderRadius: ms(8),
|
|
148
|
-
paddingHorizontal: s(
|
|
149
|
-
paddingVertical: vs(
|
|
148
|
+
paddingHorizontal: s(14),
|
|
149
|
+
paddingVertical: vs(11),
|
|
150
150
|
},
|
|
151
151
|
input: {
|
|
152
|
+
fontFamily: 'Poppins-Regular',
|
|
152
153
|
flex: 1,
|
|
153
|
-
fontSize: ms(
|
|
154
|
+
fontSize: ms(15),
|
|
154
155
|
paddingVertical: 0,
|
|
155
156
|
},
|
|
156
157
|
prefixContainer: {
|
|
157
158
|
marginRight: s(8),
|
|
158
159
|
},
|
|
159
160
|
prefixText: {
|
|
160
|
-
|
|
161
|
+
fontFamily: 'Poppins-Regular',
|
|
162
|
+
fontSize: ms(15),
|
|
161
163
|
marginRight: s(8),
|
|
162
164
|
},
|
|
163
165
|
suffixContainer: {
|
|
164
166
|
marginLeft: s(8),
|
|
165
167
|
},
|
|
166
168
|
suffixText: {
|
|
167
|
-
|
|
169
|
+
fontFamily: 'Poppins-Regular',
|
|
170
|
+
fontSize: ms(15),
|
|
168
171
|
marginLeft: s(8),
|
|
169
172
|
},
|
|
170
173
|
passwordToggle: {
|
|
171
174
|
padding: s(4),
|
|
172
175
|
},
|
|
173
176
|
helperText: {
|
|
177
|
+
fontFamily: 'Poppins-Regular',
|
|
174
178
|
fontSize: ms(13),
|
|
175
179
|
},
|
|
176
180
|
})
|
|
@@ -36,13 +36,14 @@ const styles = StyleSheet.create({
|
|
|
36
36
|
gap: s(12),
|
|
37
37
|
},
|
|
38
38
|
label: {
|
|
39
|
+
fontFamily: 'Poppins-Regular',
|
|
39
40
|
fontSize: ms(13),
|
|
40
41
|
lineHeight: mvs(18),
|
|
41
42
|
},
|
|
42
43
|
value: {
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
lineHeight: mvs(
|
|
44
|
+
fontFamily: 'Poppins-Medium',
|
|
45
|
+
fontSize: ms(14),
|
|
46
|
+
lineHeight: mvs(20),
|
|
46
47
|
textAlign: 'right',
|
|
47
48
|
},
|
|
48
49
|
})
|
|
@@ -229,7 +229,7 @@ const styles = StyleSheet.create({
|
|
|
229
229
|
flexDirection: 'row',
|
|
230
230
|
alignItems: 'center',
|
|
231
231
|
paddingHorizontal: s(16),
|
|
232
|
-
paddingVertical: vs(
|
|
232
|
+
paddingVertical: vs(10),
|
|
233
233
|
gap: s(12),
|
|
234
234
|
},
|
|
235
235
|
leftContainer: {
|
|
@@ -244,18 +244,18 @@ const styles = StyleSheet.create({
|
|
|
244
244
|
gap: vs(4),
|
|
245
245
|
},
|
|
246
246
|
title: {
|
|
247
|
-
|
|
248
|
-
|
|
249
|
-
lineHeight: mvs(
|
|
247
|
+
fontFamily: 'Poppins-Medium',
|
|
248
|
+
fontSize: ms(15),
|
|
249
|
+
lineHeight: mvs(22),
|
|
250
250
|
},
|
|
251
251
|
subtitle: {
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
lineHeight: mvs(
|
|
252
|
+
fontFamily: 'Poppins-Regular',
|
|
253
|
+
fontSize: ms(13),
|
|
254
|
+
lineHeight: mvs(18),
|
|
255
255
|
},
|
|
256
256
|
caption: {
|
|
257
|
+
fontFamily: 'Poppins-Regular',
|
|
257
258
|
fontSize: ms(12),
|
|
258
|
-
fontWeight: '400',
|
|
259
259
|
lineHeight: mvs(16),
|
|
260
260
|
opacity: 0.7,
|
|
261
261
|
},
|
|
@@ -266,7 +266,8 @@ const styles = StyleSheet.create({
|
|
|
266
266
|
maxWidth: s(160),
|
|
267
267
|
},
|
|
268
268
|
rightText: {
|
|
269
|
-
|
|
269
|
+
fontFamily: 'Poppins-Regular',
|
|
270
|
+
fontSize: ms(14),
|
|
270
271
|
},
|
|
271
272
|
chevron: {
|
|
272
273
|
marginLeft: s(4),
|
|
@@ -42,42 +42,42 @@ function RadioItem({
|
|
|
42
42
|
}
|
|
43
43
|
|
|
44
44
|
return (
|
|
45
|
-
<
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
45
|
+
<TouchableOpacity
|
|
46
|
+
style={styles.row}
|
|
47
|
+
onPress={() => {
|
|
48
|
+
if (!option.disabled) {
|
|
49
|
+
hapticSelection()
|
|
50
|
+
onSelect()
|
|
51
|
+
}
|
|
52
|
+
}}
|
|
53
|
+
onPressIn={handlePressIn}
|
|
54
|
+
onPressOut={handlePressOut}
|
|
55
|
+
activeOpacity={1}
|
|
56
|
+
touchSoundDisabled={true}
|
|
57
|
+
disabled={option.disabled}
|
|
58
|
+
>
|
|
59
|
+
<Animated.View
|
|
60
|
+
style={[
|
|
61
|
+
styles.radio,
|
|
62
|
+
{
|
|
63
|
+
borderColor: selected ? colors.primary : colors.border,
|
|
64
|
+
opacity: option.disabled ? 0.45 : 1,
|
|
65
|
+
transform: [{ scale }],
|
|
66
|
+
},
|
|
67
|
+
]}
|
|
59
68
|
>
|
|
60
|
-
<View
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
style={[
|
|
73
|
-
styles.label,
|
|
74
|
-
{ color: option.disabled ? colors.mutedForeground : colors.foreground },
|
|
75
|
-
]}
|
|
76
|
-
>
|
|
77
|
-
{option.label}
|
|
78
|
-
</Text>
|
|
79
|
-
</TouchableOpacity>
|
|
80
|
-
</Animated.View>
|
|
69
|
+
{selected ? <View style={[styles.dot, { backgroundColor: colors.primary }]} /> : null}
|
|
70
|
+
</Animated.View>
|
|
71
|
+
<Text
|
|
72
|
+
style={[
|
|
73
|
+
styles.label,
|
|
74
|
+
{ color: option.disabled ? colors.mutedForeground : colors.foreground },
|
|
75
|
+
]}
|
|
76
|
+
allowFontScaling={true}
|
|
77
|
+
>
|
|
78
|
+
{option.label}
|
|
79
|
+
</Text>
|
|
80
|
+
</TouchableOpacity>
|
|
81
81
|
)
|
|
82
82
|
}
|
|
83
83
|
|
|
@@ -129,6 +129,7 @@ const styles = StyleSheet.create({
|
|
|
129
129
|
borderRadius: s(5),
|
|
130
130
|
},
|
|
131
131
|
label: {
|
|
132
|
+
fontFamily: 'Poppins-Regular',
|
|
132
133
|
fontSize: ms(14),
|
|
133
134
|
lineHeight: mvs(20),
|
|
134
135
|
},
|