@designbasekorea/ui-native 0.1.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/README.md +152 -0
- package/dist/components/Alert/Alert.d.ts +29 -0
- package/dist/components/Alert/Alert.d.ts.map +1 -0
- package/dist/components/Alert/Alert.js +44 -0
- package/dist/components/Alert/Alert.js.map +1 -0
- package/dist/components/Alert/index.d.ts +3 -0
- package/dist/components/Alert/index.d.ts.map +1 -0
- package/dist/components/Alert/index.js +2 -0
- package/dist/components/Alert/index.js.map +1 -0
- package/dist/components/Avatar/Avatar.d.ts +28 -0
- package/dist/components/Avatar/Avatar.d.ts.map +1 -0
- package/dist/components/Avatar/Avatar.js +73 -0
- package/dist/components/Avatar/Avatar.js.map +1 -0
- package/dist/components/Avatar/index.d.ts +3 -0
- package/dist/components/Avatar/index.d.ts.map +1 -0
- package/dist/components/Avatar/index.js +2 -0
- package/dist/components/Avatar/index.js.map +1 -0
- package/dist/components/Badge/Badge.d.ts +28 -0
- package/dist/components/Badge/Badge.d.ts.map +1 -0
- package/dist/components/Badge/Badge.js +52 -0
- package/dist/components/Badge/Badge.js.map +1 -0
- package/dist/components/Badge/index.d.ts +3 -0
- package/dist/components/Badge/index.d.ts.map +1 -0
- package/dist/components/Badge/index.js +2 -0
- package/dist/components/Badge/index.js.map +1 -0
- package/dist/components/BottomNavigation/BottomNavigation.d.ts +30 -0
- package/dist/components/BottomNavigation/BottomNavigation.d.ts.map +1 -0
- package/dist/components/BottomNavigation/BottomNavigation.js +48 -0
- package/dist/components/BottomNavigation/BottomNavigation.js.map +1 -0
- package/dist/components/BottomNavigation/index.d.ts +3 -0
- package/dist/components/BottomNavigation/index.d.ts.map +1 -0
- package/dist/components/BottomNavigation/index.js +2 -0
- package/dist/components/BottomNavigation/index.js.map +1 -0
- package/dist/components/BottomSheet/BottomSheet.d.ts +26 -0
- package/dist/components/BottomSheet/BottomSheet.d.ts.map +1 -0
- package/dist/components/BottomSheet/BottomSheet.js +75 -0
- package/dist/components/BottomSheet/BottomSheet.js.map +1 -0
- package/dist/components/BottomSheet/index.d.ts +3 -0
- package/dist/components/BottomSheet/index.d.ts.map +1 -0
- package/dist/components/BottomSheet/index.js +2 -0
- package/dist/components/BottomSheet/index.js.map +1 -0
- package/dist/components/Button/Button.d.ts +53 -0
- package/dist/components/Button/Button.d.ts.map +1 -0
- package/dist/components/Button/Button.js +129 -0
- package/dist/components/Button/Button.js.map +1 -0
- package/dist/components/Button/index.d.ts +3 -0
- package/dist/components/Button/index.d.ts.map +1 -0
- package/dist/components/Button/index.js +2 -0
- package/dist/components/Button/index.js.map +1 -0
- package/dist/components/Card/Card.d.ts +36 -0
- package/dist/components/Card/Card.d.ts.map +1 -0
- package/dist/components/Card/Card.js +61 -0
- package/dist/components/Card/Card.js.map +1 -0
- package/dist/components/Card/index.d.ts +3 -0
- package/dist/components/Card/index.d.ts.map +1 -0
- package/dist/components/Card/index.js +2 -0
- package/dist/components/Card/index.js.map +1 -0
- package/dist/components/Checkbox/Checkbox.d.ts +26 -0
- package/dist/components/Checkbox/Checkbox.d.ts.map +1 -0
- package/dist/components/Checkbox/Checkbox.js +57 -0
- package/dist/components/Checkbox/Checkbox.js.map +1 -0
- package/dist/components/Checkbox/index.d.ts +3 -0
- package/dist/components/Checkbox/index.d.ts.map +1 -0
- package/dist/components/Checkbox/index.js +2 -0
- package/dist/components/Checkbox/index.js.map +1 -0
- package/dist/components/Chip/Chip.d.ts +29 -0
- package/dist/components/Chip/Chip.d.ts.map +1 -0
- package/dist/components/Chip/Chip.js +54 -0
- package/dist/components/Chip/Chip.js.map +1 -0
- package/dist/components/Chip/index.d.ts +3 -0
- package/dist/components/Chip/index.d.ts.map +1 -0
- package/dist/components/Chip/index.js +2 -0
- package/dist/components/Chip/index.js.map +1 -0
- package/dist/components/Divider/Divider.d.ts +22 -0
- package/dist/components/Divider/Divider.d.ts.map +1 -0
- package/dist/components/Divider/Divider.js +16 -0
- package/dist/components/Divider/Divider.js.map +1 -0
- package/dist/components/Divider/index.d.ts +3 -0
- package/dist/components/Divider/index.d.ts.map +1 -0
- package/dist/components/Divider/index.js +2 -0
- package/dist/components/Divider/index.js.map +1 -0
- package/dist/components/Input/Input.d.ts +33 -0
- package/dist/components/Input/Input.d.ts.map +1 -0
- package/dist/components/Input/Input.js +98 -0
- package/dist/components/Input/Input.js.map +1 -0
- package/dist/components/Input/index.d.ts +3 -0
- package/dist/components/Input/index.d.ts.map +1 -0
- package/dist/components/Input/index.js +2 -0
- package/dist/components/Input/index.js.map +1 -0
- package/dist/components/Modal/Modal.d.ts +28 -0
- package/dist/components/Modal/Modal.d.ts.map +1 -0
- package/dist/components/Modal/Modal.js +46 -0
- package/dist/components/Modal/Modal.js.map +1 -0
- package/dist/components/Modal/index.d.ts +3 -0
- package/dist/components/Modal/index.d.ts.map +1 -0
- package/dist/components/Modal/index.js +2 -0
- package/dist/components/Modal/index.js.map +1 -0
- package/dist/components/Navbar/Navbar.d.ts +50 -0
- package/dist/components/Navbar/Navbar.d.ts.map +1 -0
- package/dist/components/Navbar/Navbar.js +125 -0
- package/dist/components/Navbar/Navbar.js.map +1 -0
- package/dist/components/Navbar/index.d.ts +3 -0
- package/dist/components/Navbar/index.d.ts.map +1 -0
- package/dist/components/Navbar/index.js +2 -0
- package/dist/components/Navbar/index.js.map +1 -0
- package/dist/components/ProgressBar/ProgressBar.d.ts +27 -0
- package/dist/components/ProgressBar/ProgressBar.d.ts.map +1 -0
- package/dist/components/ProgressBar/ProgressBar.js +55 -0
- package/dist/components/ProgressBar/ProgressBar.js.map +1 -0
- package/dist/components/ProgressBar/index.d.ts +3 -0
- package/dist/components/ProgressBar/index.d.ts.map +1 -0
- package/dist/components/ProgressBar/index.js +2 -0
- package/dist/components/ProgressBar/index.js.map +1 -0
- package/dist/components/Radio/Radio.d.ts +30 -0
- package/dist/components/Radio/Radio.d.ts.map +1 -0
- package/dist/components/Radio/Radio.js +56 -0
- package/dist/components/Radio/Radio.js.map +1 -0
- package/dist/components/Radio/index.d.ts +3 -0
- package/dist/components/Radio/index.d.ts.map +1 -0
- package/dist/components/Radio/index.js +2 -0
- package/dist/components/Radio/index.js.map +1 -0
- package/dist/components/SearchBar/SearchBar.d.ts +29 -0
- package/dist/components/SearchBar/SearchBar.d.ts.map +1 -0
- package/dist/components/SearchBar/SearchBar.js +64 -0
- package/dist/components/SearchBar/SearchBar.js.map +1 -0
- package/dist/components/SearchBar/index.d.ts +3 -0
- package/dist/components/SearchBar/index.d.ts.map +1 -0
- package/dist/components/SearchBar/index.js +2 -0
- package/dist/components/SearchBar/index.js.map +1 -0
- package/dist/components/Skeleton/Skeleton.d.ts +22 -0
- package/dist/components/Skeleton/Skeleton.d.ts.map +1 -0
- package/dist/components/Skeleton/Skeleton.js +46 -0
- package/dist/components/Skeleton/Skeleton.js.map +1 -0
- package/dist/components/Skeleton/index.d.ts +3 -0
- package/dist/components/Skeleton/index.d.ts.map +1 -0
- package/dist/components/Skeleton/index.js +2 -0
- package/dist/components/Skeleton/index.js.map +1 -0
- package/dist/components/Spinner/Spinner.d.ts +23 -0
- package/dist/components/Spinner/Spinner.d.ts.map +1 -0
- package/dist/components/Spinner/Spinner.js +19 -0
- package/dist/components/Spinner/Spinner.js.map +1 -0
- package/dist/components/Spinner/index.d.ts +3 -0
- package/dist/components/Spinner/index.d.ts.map +1 -0
- package/dist/components/Spinner/index.js +2 -0
- package/dist/components/Spinner/index.js.map +1 -0
- package/dist/components/Tabs/Tabs.d.ts +30 -0
- package/dist/components/Tabs/Tabs.d.ts.map +1 -0
- package/dist/components/Tabs/Tabs.js +73 -0
- package/dist/components/Tabs/Tabs.js.map +1 -0
- package/dist/components/Tabs/index.d.ts +3 -0
- package/dist/components/Tabs/index.d.ts.map +1 -0
- package/dist/components/Tabs/index.js +2 -0
- package/dist/components/Tabs/index.js.map +1 -0
- package/dist/components/Toast/Toast.d.ts +30 -0
- package/dist/components/Toast/Toast.d.ts.map +1 -0
- package/dist/components/Toast/Toast.js +84 -0
- package/dist/components/Toast/Toast.js.map +1 -0
- package/dist/components/Toast/index.d.ts +3 -0
- package/dist/components/Toast/index.d.ts.map +1 -0
- package/dist/components/Toast/index.js +2 -0
- package/dist/components/Toast/index.js.map +1 -0
- package/dist/components/Toggle/Toggle.d.ts +26 -0
- package/dist/components/Toggle/Toggle.d.ts.map +1 -0
- package/dist/components/Toggle/Toggle.js +75 -0
- package/dist/components/Toggle/Toggle.js.map +1 -0
- package/dist/components/Toggle/index.d.ts +3 -0
- package/dist/components/Toggle/index.d.ts.map +1 -0
- package/dist/components/Toggle/index.js +2 -0
- package/dist/components/Toggle/index.js.map +1 -0
- package/dist/index.d.ts +61 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +43 -0
- package/dist/index.js.map +1 -0
- package/dist/theme/ThemeProvider.d.ts +35 -0
- package/dist/theme/ThemeProvider.d.ts.map +1 -0
- package/dist/theme/ThemeProvider.js +45 -0
- package/dist/theme/ThemeProvider.js.map +1 -0
- package/dist/theme/index.d.ts +6 -0
- package/dist/theme/index.d.ts.map +1 -0
- package/dist/theme/index.js +4 -0
- package/dist/theme/index.js.map +1 -0
- package/dist/theme/tokens.d.ts +55 -0
- package/dist/theme/tokens.d.ts.map +1 -0
- package/dist/theme/tokens.js +172 -0
- package/dist/theme/tokens.js.map +1 -0
- package/dist/theme/useTheme.d.ts +25 -0
- package/dist/theme/useTheme.d.ts.map +1 -0
- package/dist/theme/useTheme.js +33 -0
- package/dist/theme/useTheme.js.map +1 -0
- package/package.json +58 -0
- package/src/components/Alert/Alert.tsx +105 -0
- package/src/components/Alert/index.ts +2 -0
- package/src/components/Avatar/Avatar.tsx +122 -0
- package/src/components/Avatar/index.ts +2 -0
- package/src/components/Badge/Badge.tsx +100 -0
- package/src/components/Badge/index.ts +2 -0
- package/src/components/BottomNavigation/BottomNavigation.tsx +104 -0
- package/src/components/BottomNavigation/index.ts +2 -0
- package/src/components/BottomSheet/BottomSheet.tsx +127 -0
- package/src/components/BottomSheet/index.ts +2 -0
- package/src/components/Button/Button.tsx +255 -0
- package/src/components/Button/index.ts +2 -0
- package/src/components/Card/Card.tsx +147 -0
- package/src/components/Card/index.ts +2 -0
- package/src/components/Checkbox/Checkbox.tsx +95 -0
- package/src/components/Checkbox/index.ts +2 -0
- package/src/components/Chip/Chip.tsx +108 -0
- package/src/components/Chip/index.ts +2 -0
- package/src/components/Divider/Divider.tsx +41 -0
- package/src/components/Divider/index.ts +2 -0
- package/src/components/Input/Input.tsx +199 -0
- package/src/components/Input/index.ts +2 -0
- package/src/components/Modal/Modal.tsx +117 -0
- package/src/components/Modal/index.ts +2 -0
- package/src/components/Navbar/Navbar.tsx +278 -0
- package/src/components/Navbar/index.ts +2 -0
- package/src/components/ProgressBar/ProgressBar.tsx +99 -0
- package/src/components/ProgressBar/index.ts +2 -0
- package/src/components/Radio/Radio.tsx +103 -0
- package/src/components/Radio/index.ts +2 -0
- package/src/components/SearchBar/SearchBar.tsx +115 -0
- package/src/components/SearchBar/index.ts +2 -0
- package/src/components/Skeleton/Skeleton.tsx +74 -0
- package/src/components/Skeleton/index.ts +2 -0
- package/src/components/Spinner/Spinner.tsx +58 -0
- package/src/components/Spinner/index.ts +2 -0
- package/src/components/Tabs/Tabs.tsx +124 -0
- package/src/components/Tabs/index.ts +2 -0
- package/src/components/Toast/Toast.tsx +128 -0
- package/src/components/Toast/index.ts +2 -0
- package/src/components/Toggle/Toggle.tsx +109 -0
- package/src/components/Toggle/index.ts +2 -0
- package/src/index.ts +87 -0
- package/src/theme/ThemeProvider.tsx +96 -0
- package/src/theme/index.ts +5 -0
- package/src/theme/tokens.ts +225 -0
- package/src/theme/useTheme.ts +37 -0
|
@@ -0,0 +1,125 @@
|
|
|
1
|
+
import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
import { View, Text, Pressable, StyleSheet, Platform, StatusBar, } from 'react-native';
|
|
3
|
+
import { useTheme } from '../../theme/useTheme';
|
|
4
|
+
export const Navbar = ({ mode = 'stack', title, subtitle, onBack, backIcon, actions = [], showBorder = true, transparent = false, children, style, }) => {
|
|
5
|
+
const { theme } = useTheme();
|
|
6
|
+
// ─── 토큰에서 가져오기 ───
|
|
7
|
+
const surface = theme.color.aliases?.surface ?? {};
|
|
8
|
+
const textColors = theme.color.aliases?.text ?? {};
|
|
9
|
+
const borders = theme.color.aliases?.border ?? {};
|
|
10
|
+
const brand = theme.color.aliases?.brand ?? {};
|
|
11
|
+
const padding = theme.spacing.aliases?.padding ?? {};
|
|
12
|
+
const fontSize = theme.typography.foundation?.fontSize ?? {};
|
|
13
|
+
const gap = theme.spacing.aliases?.gap ?? {};
|
|
14
|
+
const iconSize = theme.size.semantic?.icon ?? {};
|
|
15
|
+
// stack 모드 = 최대 2개, tab 모드 = 최대 3개
|
|
16
|
+
const maxActions = mode === 'stack' ? 2 : 3;
|
|
17
|
+
const visibleActions = actions.slice(0, maxActions);
|
|
18
|
+
const NAVBAR_HEIGHT = 56;
|
|
19
|
+
const statusBarHeight = Platform.OS === 'android' ? (StatusBar.currentHeight ?? 0) : 0;
|
|
20
|
+
const renderAction = (action, index) => (_jsx(Pressable, { onPress: action.onPress, disabled: action.disabled, accessibilityRole: "button", accessibilityLabel: action.label, hitSlop: 8, style: ({ pressed }) => [
|
|
21
|
+
styles.actionButton,
|
|
22
|
+
{
|
|
23
|
+
width: iconSize.xl ?? 32,
|
|
24
|
+
height: iconSize.xl ?? 32,
|
|
25
|
+
},
|
|
26
|
+
action.disabled && { opacity: theme.opacity.foundation?.[40] ?? 0.4 },
|
|
27
|
+
pressed && { opacity: 0.6 },
|
|
28
|
+
], children: action.icon ?? (_jsx(Text, { style: {
|
|
29
|
+
fontSize: fontSize.s ?? 14,
|
|
30
|
+
fontWeight: '500',
|
|
31
|
+
color: brand.primary ?? '#006FFF',
|
|
32
|
+
}, children: action.label })) }, index));
|
|
33
|
+
return (_jsxs(View, { style: [
|
|
34
|
+
styles.wrapper,
|
|
35
|
+
{
|
|
36
|
+
paddingTop: statusBarHeight,
|
|
37
|
+
backgroundColor: transparent ? 'transparent' : (surface.base ?? '#FFFFFF'),
|
|
38
|
+
borderBottomWidth: showBorder ? 1 : 0,
|
|
39
|
+
borderBottomColor: borders.base ?? '#E8EEF2',
|
|
40
|
+
},
|
|
41
|
+
style,
|
|
42
|
+
], children: [_jsx(View, { style: [
|
|
43
|
+
styles.container,
|
|
44
|
+
{
|
|
45
|
+
height: NAVBAR_HEIGHT,
|
|
46
|
+
paddingHorizontal: padding.m ?? 12,
|
|
47
|
+
},
|
|
48
|
+
], children: mode === 'stack' ? (
|
|
49
|
+
/* ── Stack 모드: [뒤로가기] [중앙 타이틀] [액션 버튼] ── */
|
|
50
|
+
_jsxs(_Fragment, { children: [_jsx(View, { style: styles.left, children: onBack && (_jsx(Pressable, { onPress: onBack, accessibilityRole: "button", accessibilityLabel: "\uB4A4\uB85C \uAC00\uAE30", hitSlop: 12, style: ({ pressed }) => [
|
|
51
|
+
styles.backButton,
|
|
52
|
+
{
|
|
53
|
+
width: iconSize.xl ?? 32,
|
|
54
|
+
height: iconSize.xl ?? 32,
|
|
55
|
+
},
|
|
56
|
+
pressed && { opacity: 0.6 },
|
|
57
|
+
], children: backIcon ?? (_jsx(Text, { style: {
|
|
58
|
+
fontSize: fontSize.xl ?? 20,
|
|
59
|
+
color: textColors.primary ?? '#17191A',
|
|
60
|
+
}, children: "\u2190" })) })) }), _jsx(View, { style: styles.center, children: _jsx(Text, { style: [styles.stackTitle, {
|
|
61
|
+
fontSize: fontSize.base ?? 16,
|
|
62
|
+
color: textColors.primary ?? '#17191A',
|
|
63
|
+
}], numberOfLines: 1, children: title }) }), _jsx(View, { style: [styles.right, { gap: gap.xs ?? 4 }], children: visibleActions.map(renderAction) })] })) : (
|
|
64
|
+
/* ── Tab 모드: [좌측 타이틀] [우측 액션 버튼] ── */
|
|
65
|
+
_jsxs(_Fragment, { children: [_jsxs(View, { style: styles.tabLeft, children: [_jsx(Text, { style: [styles.tabTitle, {
|
|
66
|
+
fontSize: fontSize['2xl'] ?? 24,
|
|
67
|
+
color: textColors.primary ?? '#17191A',
|
|
68
|
+
}], numberOfLines: 1, children: title }), subtitle && (_jsx(Text, { style: {
|
|
69
|
+
fontSize: fontSize.xs ?? 12,
|
|
70
|
+
color: textColors.tertiary ?? '#757B80',
|
|
71
|
+
marginTop: 1,
|
|
72
|
+
}, children: subtitle }))] }), _jsx(View, { style: [styles.right, { gap: gap.xs ?? 4 }], children: visibleActions.map(renderAction) })] })) }), children && (_jsx(View, { style: {
|
|
73
|
+
paddingHorizontal: padding.m ?? 12,
|
|
74
|
+
paddingBottom: padding.s ?? 8,
|
|
75
|
+
}, children: children }))] }));
|
|
76
|
+
};
|
|
77
|
+
Navbar.displayName = 'Navbar';
|
|
78
|
+
const styles = StyleSheet.create({
|
|
79
|
+
wrapper: {},
|
|
80
|
+
container: {
|
|
81
|
+
flexDirection: 'row',
|
|
82
|
+
alignItems: 'center',
|
|
83
|
+
},
|
|
84
|
+
/* ─── Stack 모드 ─── */
|
|
85
|
+
left: {
|
|
86
|
+
width: 44,
|
|
87
|
+
alignItems: 'flex-start',
|
|
88
|
+
justifyContent: 'center',
|
|
89
|
+
},
|
|
90
|
+
center: {
|
|
91
|
+
flex: 1,
|
|
92
|
+
alignItems: 'center',
|
|
93
|
+
justifyContent: 'center',
|
|
94
|
+
},
|
|
95
|
+
right: {
|
|
96
|
+
minWidth: 44,
|
|
97
|
+
flexDirection: 'row',
|
|
98
|
+
alignItems: 'center',
|
|
99
|
+
justifyContent: 'flex-end',
|
|
100
|
+
},
|
|
101
|
+
backButton: {
|
|
102
|
+
alignItems: 'center',
|
|
103
|
+
justifyContent: 'center',
|
|
104
|
+
},
|
|
105
|
+
stackTitle: {
|
|
106
|
+
fontWeight: '600',
|
|
107
|
+
textAlign: 'center',
|
|
108
|
+
},
|
|
109
|
+
/* ─── Tab 모드 ─── */
|
|
110
|
+
tabLeft: {
|
|
111
|
+
flex: 1,
|
|
112
|
+
justifyContent: 'center',
|
|
113
|
+
},
|
|
114
|
+
tabTitle: {
|
|
115
|
+
fontWeight: '700',
|
|
116
|
+
},
|
|
117
|
+
/* ─── 공통 ─── */
|
|
118
|
+
actionButton: {
|
|
119
|
+
alignItems: 'center',
|
|
120
|
+
justifyContent: 'center',
|
|
121
|
+
borderRadius: 8,
|
|
122
|
+
},
|
|
123
|
+
});
|
|
124
|
+
export default Navbar;
|
|
125
|
+
//# sourceMappingURL=Navbar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Navbar.js","sourceRoot":"","sources":["../../../src/components/Navbar/Navbar.tsx"],"names":[],"mappings":";AAkBA,OAAO,EACH,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE,UAAU,EAAE,QAAQ,EAAE,SAAS,GAEzD,MAAM,cAAc,CAAC;AACtB,OAAO,EAAE,QAAQ,EAAE,MAAM,sBAAsB,CAAC;AAiChD,MAAM,CAAC,MAAM,MAAM,GAA0B,CAAC,EAC1C,IAAI,GAAG,OAAO,EACd,KAAK,EACL,QAAQ,EACR,MAAM,EACN,QAAQ,EACR,OAAO,GAAG,EAAE,EACZ,UAAU,GAAG,IAAI,EACjB,WAAW,GAAG,KAAK,EACnB,QAAQ,EACR,KAAK,GACR,EAAE,EAAE;IACD,MAAM,EAAE,KAAK,EAAE,GAAG,QAAQ,EAAE,CAAC;IAE7B,oBAAoB;IACpB,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,OAAO,IAAI,EAAE,CAAC;IACnD,MAAM,UAAU,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,IAAI,IAAI,EAAE,CAAC;IACnD,MAAM,OAAO,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,MAAM,IAAI,EAAE,CAAC;IAClD,MAAM,KAAK,GAAG,KAAK,CAAC,KAAK,CAAC,OAAO,EAAE,KAAK,IAAI,EAAE,CAAC;IAC/C,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,EAAE,OAAO,IAAI,EAAE,CAAC;IACrD,MAAM,QAAQ,GAAG,KAAK,CAAC,UAAU,CAAC,UAAU,EAAE,QAAQ,IAAI,EAAE,CAAC;IAC7D,MAAM,GAAG,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,EAAE,GAAG,IAAI,EAAE,CAAC;IAC7C,MAAM,QAAQ,GAAG,KAAK,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,IAAI,EAAE,CAAC;IAEjD,mCAAmC;IACnC,MAAM,UAAU,GAAG,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5C,MAAM,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,CAAC,EAAE,UAAU,CAAC,CAAC;IAEpD,MAAM,aAAa,GAAG,EAAE,CAAC;IACzB,MAAM,eAAe,GAAG,QAAQ,CAAC,EAAE,KAAK,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,aAAa,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAEvF,MAAM,YAAY,GAAG,CAAC,MAAoB,EAAE,KAAa,EAAE,EAAE,CAAC,CAC1D,KAAC,SAAS,IAEN,OAAO,EAAE,MAAM,CAAC,OAAO,EACvB,QAAQ,EAAE,MAAM,CAAC,QAAQ,EACzB,iBAAiB,EAAC,QAAQ,EAC1B,kBAAkB,EAAE,MAAM,CAAC,KAAK,EAChC,OAAO,EAAE,CAAC,EACV,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;YACpB,MAAM,CAAC,YAAY;YACnB;gBACI,KAAK,EAAE,QAAQ,CAAC,EAAE,IAAI,EAAE;gBACxB,MAAM,EAAE,QAAQ,CAAC,EAAE,IAAI,EAAE;aAC5B;YACD,MAAM,CAAC,QAAQ,IAAI,EAAE,OAAO,EAAE,KAAK,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC,EAAE,CAAC,IAAI,GAAG,EAAE;YACrE,OAAO,IAAI,EAAE,OAAO,EAAE,GAAG,EAAE;SAC9B,YAEA,MAAM,CAAC,IAAI,IAAI,CACZ,KAAC,IAAI,IAAC,KAAK,EAAE;gBACT,QAAQ,EAAE,QAAQ,CAAC,CAAC,IAAI,EAAE;gBAC1B,UAAU,EAAE,KAAK;gBACjB,KAAK,EAAE,KAAK,CAAC,OAAO,IAAI,SAAS;aACpC,YACI,MAAM,CAAC,KAAK,GACV,CACV,IAxBI,KAAK,CAyBF,CACf,CAAC;IAEF,OAAO,CACH,MAAC,IAAI,IAAC,KAAK,EAAE;YACT,MAAM,CAAC,OAAO;YACd;gBACI,UAAU,EAAE,eAAe;gBAC3B,eAAe,EAAE,WAAW,CAAC,CAAC,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,IAAI,IAAI,SAAS,CAAC;gBAC1E,iBAAiB,EAAE,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBACrC,iBAAiB,EAAE,OAAO,CAAC,IAAI,IAAI,SAAS;aAC/C;YACD,KAAK;SACR,aACG,KAAC,IAAI,IAAC,KAAK,EAAE;oBACT,MAAM,CAAC,SAAS;oBAChB;wBACI,MAAM,EAAE,aAAa;wBACrB,iBAAiB,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE;qBACrC;iBACJ,YACI,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC;gBAChB,6CAA6C;gBAC7C,8BACI,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,IAAI,YACnB,MAAM,IAAI,CACP,KAAC,SAAS,IACN,OAAO,EAAE,MAAM,EACf,iBAAiB,EAAC,QAAQ,EAC1B,kBAAkB,EAAC,2BAAO,EAC1B,OAAO,EAAE,EAAE,EACX,KAAK,EAAE,CAAC,EAAE,OAAO,EAAE,EAAE,EAAE,CAAC;oCACpB,MAAM,CAAC,UAAU;oCACjB;wCACI,KAAK,EAAE,QAAQ,CAAC,EAAE,IAAI,EAAE;wCACxB,MAAM,EAAE,QAAQ,CAAC,EAAE,IAAI,EAAE;qCAC5B;oCACD,OAAO,IAAI,EAAE,OAAO,EAAE,GAAG,EAAE;iCAC9B,YAEA,QAAQ,IAAI,CACT,KAAC,IAAI,IAAC,KAAK,EAAE;wCACT,QAAQ,EAAE,QAAQ,CAAC,EAAE,IAAI,EAAE;wCAC3B,KAAK,EAAE,UAAU,CAAC,OAAO,IAAI,SAAS;qCACzC,uBAEM,CACV,GACO,CACf,GACE,EAEP,KAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,MAAM,YACtB,KAAC,IAAI,IACD,KAAK,EAAE,CAAC,MAAM,CAAC,UAAU,EAAE;wCACvB,QAAQ,EAAE,QAAQ,CAAC,IAAI,IAAI,EAAE;wCAC7B,KAAK,EAAE,UAAU,CAAC,OAAO,IAAI,SAAS;qCACzC,CAAC,EACF,aAAa,EAAE,CAAC,YAEf,KAAK,GACH,GACJ,EAEP,KAAC,IAAI,IAAC,KAAK,EAAE,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,YAC5C,cAAc,CAAC,GAAG,CAAC,YAAY,CAAC,GAC9B,IACR,CACN,CAAC,CAAC,CAAC;gBACA,uCAAuC;gBACvC,8BACI,MAAC,IAAI,IAAC,KAAK,EAAE,MAAM,CAAC,OAAO,aACvB,KAAC,IAAI,IACD,KAAK,EAAE,CAAC,MAAM,CAAC,QAAQ,EAAE;4CACrB,QAAQ,EAAE,QAAQ,CAAC,KAAK,CAAC,IAAI,EAAE;4CAC/B,KAAK,EAAE,UAAU,CAAC,OAAO,IAAI,SAAS;yCACzC,CAAC,EACF,aAAa,EAAE,CAAC,YAEf,KAAK,GACH,EACN,QAAQ,IAAI,CACT,KAAC,IAAI,IAAC,KAAK,EAAE;wCACT,QAAQ,EAAE,QAAQ,CAAC,EAAE,IAAI,EAAE;wCAC3B,KAAK,EAAE,UAAU,CAAC,QAAQ,IAAI,SAAS;wCACvC,SAAS,EAAE,CAAC;qCACf,YACI,QAAQ,GACN,CACV,IACE,EAEP,KAAC,IAAI,IAAC,KAAK,EAAE,CAAC,MAAM,CAAC,KAAK,EAAE,EAAE,GAAG,EAAE,GAAG,CAAC,EAAE,IAAI,CAAC,EAAE,CAAC,YAC5C,cAAc,CAAC,GAAG,CAAC,YAAY,CAAC,GAC9B,IACR,CACN,GACE,EAGN,QAAQ,IAAI,CACT,KAAC,IAAI,IAAC,KAAK,EAAE;oBACT,iBAAiB,EAAE,OAAO,CAAC,CAAC,IAAI,EAAE;oBAClC,aAAa,EAAE,OAAO,CAAC,CAAC,IAAI,CAAC;iBAChC,YACI,QAAQ,GACN,CACV,IACE,CACV,CAAC;AACN,CAAC,CAAC;AAEF,MAAM,CAAC,WAAW,GAAG,QAAQ,CAAC;AAE9B,MAAM,MAAM,GAAG,UAAU,CAAC,MAAM,CAAC;IAC7B,OAAO,EAAE,EAAE;IACX,SAAS,EAAE;QACP,aAAa,EAAE,KAAK;QACpB,UAAU,EAAE,QAAQ;KACvB;IAED,sBAAsB;IACtB,IAAI,EAAE;QACF,KAAK,EAAE,EAAE;QACT,UAAU,EAAE,YAAY;QACxB,cAAc,EAAE,QAAQ;KAC3B;IACD,MAAM,EAAE;QACJ,IAAI,EAAE,CAAC;QACP,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;KAC3B;IACD,KAAK,EAAE;QACH,QAAQ,EAAE,EAAE;QACZ,aAAa,EAAE,KAAK;QACpB,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,UAAU;KAC7B;IACD,UAAU,EAAE;QACR,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;KAC3B;IACD,UAAU,EAAE;QACR,UAAU,EAAE,KAAK;QACjB,SAAS,EAAE,QAAQ;KACtB;IAED,oBAAoB;IACpB,OAAO,EAAE;QACL,IAAI,EAAE,CAAC;QACP,cAAc,EAAE,QAAQ;KAC3B;IACD,QAAQ,EAAE;QACN,UAAU,EAAE,KAAK;KACpB;IAED,gBAAgB;IAChB,YAAY,EAAE;QACV,UAAU,EAAE,QAAQ;QACpB,cAAc,EAAE,QAAQ;QACxB,YAAY,EAAE,CAAC;KAClB;CACJ,CAAC,CAAC;AAEH,eAAe,MAAM,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Navbar/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,YAAY,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Navbar/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* ProgressBar 컴포넌트 (React Native)
|
|
3
|
+
*
|
|
4
|
+
* 스타일링 토큰 경로:
|
|
5
|
+
* - 트랙: theme.color.aliases.surface.{layer-2}
|
|
6
|
+
* - 바: theme.color.aliases.{brand.primary|feedback.*.fg}
|
|
7
|
+
* - 라운드: theme.border.semantic.radius.full
|
|
8
|
+
* - 폰트: theme.typography.foundation.fontSize.xs
|
|
9
|
+
* - 텍스트: theme.color.aliases.text.secondary
|
|
10
|
+
*/
|
|
11
|
+
import React from 'react';
|
|
12
|
+
import { type ViewStyle } from 'react-native';
|
|
13
|
+
export type ProgressBarVariant = 'primary' | 'success' | 'warning' | 'danger' | 'info';
|
|
14
|
+
export type ProgressBarSize = 's' | 'm' | 'l';
|
|
15
|
+
export interface ProgressBarProps {
|
|
16
|
+
value: number;
|
|
17
|
+
max?: number;
|
|
18
|
+
variant?: ProgressBarVariant;
|
|
19
|
+
size?: ProgressBarSize;
|
|
20
|
+
showLabel?: boolean;
|
|
21
|
+
label?: string;
|
|
22
|
+
animated?: boolean;
|
|
23
|
+
style?: ViewStyle;
|
|
24
|
+
}
|
|
25
|
+
export declare const ProgressBar: React.FC<ProgressBarProps>;
|
|
26
|
+
export default ProgressBar;
|
|
27
|
+
//# sourceMappingURL=ProgressBar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProgressBar.d.ts","sourceRoot":"","sources":["../../../src/components/ProgressBar/ProgressBar.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAA4B,MAAM,OAAO,CAAC;AACjD,OAAO,EAAoC,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAGhF,MAAM,MAAM,kBAAkB,GAAG,SAAS,GAAG,SAAS,GAAG,SAAS,GAAG,QAAQ,GAAG,MAAM,CAAC;AACvF,MAAM,MAAM,eAAe,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAE9C,MAAM,WAAW,gBAAgB;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,OAAO,CAAC,EAAE,kBAAkB,CAAC;IAC7B,IAAI,CAAC,EAAE,eAAe,CAAC;IACvB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,SAAS,CAAC;CACrB;AAED,eAAO,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,CA0DlD,CAAC;AAWF,eAAe,WAAW,CAAC"}
|
|
@@ -0,0 +1,55 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* ProgressBar 컴포넌트 (React Native)
|
|
4
|
+
*
|
|
5
|
+
* 스타일링 토큰 경로:
|
|
6
|
+
* - 트랙: theme.color.aliases.surface.{layer-2}
|
|
7
|
+
* - 바: theme.color.aliases.{brand.primary|feedback.*.fg}
|
|
8
|
+
* - 라운드: theme.border.semantic.radius.full
|
|
9
|
+
* - 폰트: theme.typography.foundation.fontSize.xs
|
|
10
|
+
* - 텍스트: theme.color.aliases.text.secondary
|
|
11
|
+
*/
|
|
12
|
+
import { useRef, useEffect } from 'react';
|
|
13
|
+
import { View, Text, Animated, StyleSheet } from 'react-native';
|
|
14
|
+
import { useTheme } from '../../theme/useTheme';
|
|
15
|
+
export const ProgressBar = ({ value, max = 100, variant = 'primary', size = 'm', showLabel = false, label, animated = true, style, }) => {
|
|
16
|
+
const { theme } = useTheme();
|
|
17
|
+
const animatedWidth = useRef(new Animated.Value(0)).current;
|
|
18
|
+
const surface = theme.color.aliases?.surface ?? {};
|
|
19
|
+
const brand = theme.color.aliases?.brand ?? {};
|
|
20
|
+
const feedback = theme.color.aliases?.feedback ?? {};
|
|
21
|
+
const textColors = theme.color.aliases?.text ?? {};
|
|
22
|
+
const fontSize = theme.typography.foundation?.fontSize ?? {};
|
|
23
|
+
const percentage = Math.min(100, Math.max(0, (value / max) * 100));
|
|
24
|
+
const trackHeight = { s: 4, m: 8, l: 12 }[size];
|
|
25
|
+
const barColors = {
|
|
26
|
+
primary: brand.primary ?? '#006FFF',
|
|
27
|
+
success: feedback.success?.fg ?? '#16A34A',
|
|
28
|
+
warning: feedback.warning?.fg ?? '#D1B400',
|
|
29
|
+
danger: feedback.error?.fg ?? '#DC2626',
|
|
30
|
+
info: feedback.info?.fg ?? '#0683FF',
|
|
31
|
+
};
|
|
32
|
+
useEffect(() => {
|
|
33
|
+
if (animated) {
|
|
34
|
+
Animated.spring(animatedWidth, { toValue: percentage, useNativeDriver: false, friction: 10, tension: 40 }).start();
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
animatedWidth.setValue(percentage);
|
|
38
|
+
}
|
|
39
|
+
}, [percentage, animated, animatedWidth]);
|
|
40
|
+
const barWidthInterpolation = animatedWidth.interpolate({ inputRange: [0, 100], outputRange: ['0%', '100%'] });
|
|
41
|
+
return (_jsxs(View, { style: [styles.container, style], accessibilityRole: "progressbar", accessibilityValue: { min: 0, max, now: value }, children: [(showLabel || label) && (_jsxs(View, { style: styles.labelRow, children: [_jsx(Text, { style: { fontSize: fontSize.xs ?? 12, color: textColors.secondary ?? '#464A4D' }, children: label ?? `${Math.round(percentage)}%` }), label && showLabel && (_jsxs(Text, { style: { fontSize: fontSize.xs ?? 12, color: textColors.tertiary ?? '#757B80' }, children: [Math.round(percentage), "%"] }))] })), _jsx(View, { style: [styles.track, { height: trackHeight, borderRadius: trackHeight / 2, backgroundColor: surface['layer-2'] ?? '#E8EEF2' }], children: _jsx(Animated.View, { style: [styles.bar, {
|
|
42
|
+
height: trackHeight, borderRadius: trackHeight / 2,
|
|
43
|
+
backgroundColor: barColors[variant],
|
|
44
|
+
width: barWidthInterpolation,
|
|
45
|
+
}] }) })] }));
|
|
46
|
+
};
|
|
47
|
+
ProgressBar.displayName = 'ProgressBar';
|
|
48
|
+
const styles = StyleSheet.create({
|
|
49
|
+
container: { width: '100%' },
|
|
50
|
+
labelRow: { flexDirection: 'row', justifyContent: 'space-between', marginBottom: 4 },
|
|
51
|
+
track: { overflow: 'hidden' },
|
|
52
|
+
bar: {},
|
|
53
|
+
});
|
|
54
|
+
export default ProgressBar;
|
|
55
|
+
//# sourceMappingURL=ProgressBar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"ProgressBar.js","sourceRoot":"","sources":["../../../src/components/ProgressBar/ProgressBar.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/ProgressBar/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC;AAC5C,YAAY,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,eAAe,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/ProgressBar/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,eAAe,CAAC"}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Radio 컴포넌트 (React Native)
|
|
3
|
+
*
|
|
4
|
+
* 스타일링 토큰 경로:
|
|
5
|
+
* - 색상: theme.color.aliases.{brand.primary|border.base|surface.base}
|
|
6
|
+
* - 폰트: theme.typography.foundation.fontSize.*
|
|
7
|
+
* - 간격: theme.spacing.aliases.gap.*
|
|
8
|
+
*/
|
|
9
|
+
import React from 'react';
|
|
10
|
+
import { type ViewStyle } from 'react-native';
|
|
11
|
+
export type RadioSize = 's' | 'm' | 'l';
|
|
12
|
+
export interface RadioOption {
|
|
13
|
+
value: string;
|
|
14
|
+
label: string;
|
|
15
|
+
description?: string;
|
|
16
|
+
disabled?: boolean;
|
|
17
|
+
}
|
|
18
|
+
export interface RadioProps {
|
|
19
|
+
options: RadioOption[];
|
|
20
|
+
value?: string;
|
|
21
|
+
defaultValue?: string;
|
|
22
|
+
onChange?: (value: string) => void;
|
|
23
|
+
size?: RadioSize;
|
|
24
|
+
disabled?: boolean;
|
|
25
|
+
direction?: 'vertical' | 'horizontal';
|
|
26
|
+
style?: ViewStyle;
|
|
27
|
+
}
|
|
28
|
+
export declare const Radio: React.FC<RadioProps>;
|
|
29
|
+
export default Radio;
|
|
30
|
+
//# sourceMappingURL=Radio.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Radio.d.ts","sourceRoot":"","sources":["../../../src/components/Radio/Radio.tsx"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAqC,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAGjF,MAAM,MAAM,SAAS,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAExC,MAAM,WAAW,WAAW;IACxB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACtB;AAED,MAAM,WAAW,UAAU;IACvB,OAAO,EAAE,WAAW,EAAE,CAAC;IACvB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,UAAU,GAAG,YAAY,CAAC;IACtC,KAAK,CAAC,EAAE,SAAS,CAAC;CACrB;AAED,eAAO,MAAM,KAAK,EAAE,KAAK,CAAC,EAAE,CAAC,UAAU,CAwDtC,CAAC;AAaF,eAAe,KAAK,CAAC"}
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* Radio 컴포넌트 (React Native)
|
|
4
|
+
*
|
|
5
|
+
* 스타일링 토큰 경로:
|
|
6
|
+
* - 색상: theme.color.aliases.{brand.primary|border.base|surface.base}
|
|
7
|
+
* - 폰트: theme.typography.foundation.fontSize.*
|
|
8
|
+
* - 간격: theme.spacing.aliases.gap.*
|
|
9
|
+
*/
|
|
10
|
+
import React from 'react';
|
|
11
|
+
import { View, Text, Pressable, StyleSheet } from 'react-native';
|
|
12
|
+
import { useTheme } from '../../theme/useTheme';
|
|
13
|
+
export const Radio = ({ options, value: controlledValue, defaultValue, onChange, size = 'm', disabled = false, direction = 'vertical', style, }) => {
|
|
14
|
+
const { theme } = useTheme();
|
|
15
|
+
const [internalValue, setInternalValue] = React.useState(controlledValue ?? defaultValue ?? '');
|
|
16
|
+
const selectedValue = controlledValue ?? internalValue;
|
|
17
|
+
const brand = theme.color.aliases?.brand ?? {};
|
|
18
|
+
const borders = theme.color.aliases?.border ?? {};
|
|
19
|
+
const surface = theme.color.aliases?.surface ?? {};
|
|
20
|
+
const textColors = theme.color.aliases?.text ?? {};
|
|
21
|
+
const fontSize = theme.typography.foundation?.fontSize ?? {};
|
|
22
|
+
const gap = theme.spacing.aliases?.gap ?? {};
|
|
23
|
+
const disabledOpacity = theme.opacity.foundation?.[40] ?? 0.4;
|
|
24
|
+
const outerSize = { s: 16, m: 20, l: 24 }[size];
|
|
25
|
+
const innerSize = { s: 8, m: 10, l: 14 }[size];
|
|
26
|
+
const labelFontSize = { s: fontSize.xs ?? 12, m: fontSize.s ?? 14, l: fontSize.base ?? 16 }[size];
|
|
27
|
+
const handleSelect = (val) => {
|
|
28
|
+
if (disabled)
|
|
29
|
+
return;
|
|
30
|
+
setInternalValue(val);
|
|
31
|
+
onChange?.(val);
|
|
32
|
+
};
|
|
33
|
+
return (_jsx(View, { style: [
|
|
34
|
+
direction === 'horizontal' ? styles.horizontal : styles.vertical,
|
|
35
|
+
{ gap: gap.m ?? 12 }, style,
|
|
36
|
+
], accessibilityRole: "radiogroup", children: options.map((opt) => {
|
|
37
|
+
const isSelected = selectedValue === opt.value;
|
|
38
|
+
const isDisabled = disabled || opt.disabled;
|
|
39
|
+
return (_jsxs(Pressable, { onPress: () => handleSelect(opt.value), disabled: isDisabled, accessibilityRole: "radio", accessibilityState: { checked: isSelected, disabled: isDisabled }, style: [styles.option, { gap: gap.s ?? 8 }, isDisabled && { opacity: disabledOpacity }], children: [_jsx(View, { style: [styles.outer, {
|
|
40
|
+
width: outerSize, height: outerSize, borderRadius: outerSize / 2,
|
|
41
|
+
borderColor: isSelected ? (brand.primary ?? '#006FFF') : (borders.base ?? '#E8EEF2'),
|
|
42
|
+
backgroundColor: surface.base ?? '#FFFFFF',
|
|
43
|
+
}], children: isSelected && (_jsx(View, { style: [styles.inner, { width: innerSize, height: innerSize, borderRadius: innerSize / 2, backgroundColor: brand.primary ?? '#006FFF' }] })) }), _jsxs(View, { style: styles.labelContainer, children: [_jsx(Text, { style: { fontSize: labelFontSize, color: textColors.primary ?? '#17191A' }, children: opt.label }), opt.description && _jsx(Text, { style: { fontSize: fontSize.xs ?? 12, color: textColors.tertiary ?? '#757B80' }, children: opt.description })] })] }, opt.value));
|
|
44
|
+
}) }));
|
|
45
|
+
};
|
|
46
|
+
Radio.displayName = 'Radio';
|
|
47
|
+
const styles = StyleSheet.create({
|
|
48
|
+
vertical: {},
|
|
49
|
+
horizontal: { flexDirection: 'row', flexWrap: 'wrap' },
|
|
50
|
+
option: { flexDirection: 'row', alignItems: 'flex-start' },
|
|
51
|
+
outer: { borderWidth: 2, alignItems: 'center', justifyContent: 'center' },
|
|
52
|
+
inner: {},
|
|
53
|
+
labelContainer: { flex: 1, gap: 2, paddingTop: 1 },
|
|
54
|
+
});
|
|
55
|
+
export default Radio;
|
|
56
|
+
//# sourceMappingURL=Radio.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Radio.js","sourceRoot":"","sources":["../../../src/components/Radio/Radio.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Radio/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC;AAChC,YAAY,EAAE,UAAU,EAAE,WAAW,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Radio/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,MAAM,SAAS,CAAC"}
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SearchBar 컴포넌트 (React Native)
|
|
3
|
+
*
|
|
4
|
+
* 스타일링 토큰 경로:
|
|
5
|
+
* - 색상: theme.color.semantic.field.input.*
|
|
6
|
+
* - 사이즈: theme.size.semantic.search.{s|m|l}
|
|
7
|
+
* - 라운드: theme.border.semantic.radius.{l|full}
|
|
8
|
+
* - 패딩: theme.spacing.aliases.padding.*
|
|
9
|
+
* - 폰트: theme.typography.foundation.fontSize.*
|
|
10
|
+
*/
|
|
11
|
+
import React from 'react';
|
|
12
|
+
import { type ViewStyle } from 'react-native';
|
|
13
|
+
export type SearchBarSize = 's' | 'm' | 'l';
|
|
14
|
+
export interface SearchBarProps {
|
|
15
|
+
value?: string;
|
|
16
|
+
defaultValue?: string;
|
|
17
|
+
placeholder?: string;
|
|
18
|
+
size?: SearchBarSize;
|
|
19
|
+
onChangeText?: (text: string) => void;
|
|
20
|
+
onSubmit?: (text: string) => void;
|
|
21
|
+
onClear?: () => void;
|
|
22
|
+
disabled?: boolean;
|
|
23
|
+
showClearButton?: boolean;
|
|
24
|
+
startIcon?: React.ReactNode;
|
|
25
|
+
style?: ViewStyle;
|
|
26
|
+
}
|
|
27
|
+
export declare const SearchBar: React.FC<SearchBarProps>;
|
|
28
|
+
export default SearchBar;
|
|
29
|
+
//# sourceMappingURL=SearchBar.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SearchBar.d.ts","sourceRoot":"","sources":["../../../src/components/SearchBar/SearchBar.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;GASG;AAEH,OAAO,KAAmB,MAAM,OAAO,CAAC;AACxC,OAAO,EAAgD,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAG5F,MAAM,MAAM,aAAa,GAAG,GAAG,GAAG,GAAG,GAAG,GAAG,CAAC;AAE5C,MAAM,WAAW,cAAc;IAC3B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,aAAa,CAAC;IACrB,YAAY,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IACtC,QAAQ,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IAClC,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,SAAS,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC5B,KAAK,CAAC,EAAE,SAAS,CAAC;CACrB;AAED,eAAO,MAAM,SAAS,EAAE,KAAK,CAAC,EAAE,CAAC,cAAc,CA0E9C,CAAC;AASF,eAAe,SAAS,CAAC"}
|
|
@@ -0,0 +1,64 @@
|
|
|
1
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* SearchBar 컴포넌트 (React Native)
|
|
4
|
+
*
|
|
5
|
+
* 스타일링 토큰 경로:
|
|
6
|
+
* - 색상: theme.color.semantic.field.input.*
|
|
7
|
+
* - 사이즈: theme.size.semantic.search.{s|m|l}
|
|
8
|
+
* - 라운드: theme.border.semantic.radius.{l|full}
|
|
9
|
+
* - 패딩: theme.spacing.aliases.padding.*
|
|
10
|
+
* - 폰트: theme.typography.foundation.fontSize.*
|
|
11
|
+
*/
|
|
12
|
+
import { useState } from 'react';
|
|
13
|
+
import { View, TextInput, Text, Pressable, StyleSheet } from 'react-native';
|
|
14
|
+
import { useTheme } from '../../theme/useTheme';
|
|
15
|
+
export const SearchBar = ({ value: controlledValue, defaultValue = '', placeholder = '검색...', size = 'm', onChangeText, onSubmit, onClear, disabled = false, showClearButton = true, startIcon, style, }) => {
|
|
16
|
+
const { theme } = useTheme();
|
|
17
|
+
const [internalValue, setInternalValue] = useState(controlledValue ?? defaultValue);
|
|
18
|
+
const [isFocused, setIsFocused] = useState(false);
|
|
19
|
+
const currentValue = controlledValue ?? internalValue;
|
|
20
|
+
const fieldTokens = theme.color.semantic?.field?.input ?? {};
|
|
21
|
+
const aliases = theme.color.aliases ?? {};
|
|
22
|
+
const searchSize = theme.size.semantic?.search ?? {};
|
|
23
|
+
const padding = theme.spacing.aliases?.padding ?? {};
|
|
24
|
+
const fontSize = theme.typography.foundation?.fontSize ?? {};
|
|
25
|
+
const disabledOpacity = theme.opacity.foundation?.[40] ?? 0.4;
|
|
26
|
+
const sizeConfig = {
|
|
27
|
+
s: { height: searchSize.s ?? 32, fontSize: fontSize.xs ?? 12, paddingH: padding.s ?? 8 },
|
|
28
|
+
m: { height: searchSize.m ?? 40, fontSize: fontSize.s ?? 14, paddingH: padding.m ?? 12 },
|
|
29
|
+
l: { height: searchSize.l ?? 48, fontSize: fontSize.base ?? 16, paddingH: padding.l ?? 20 },
|
|
30
|
+
}[size];
|
|
31
|
+
const bgColor = disabled
|
|
32
|
+
? (fieldTokens['bg-disabled'] ?? aliases.surface?.muted ?? '#E8EEF2')
|
|
33
|
+
: (fieldTokens['bg-default'] ?? aliases.surface?.['layer-1'] ?? '#F2F8FC');
|
|
34
|
+
const borderColor = isFocused
|
|
35
|
+
? (fieldTokens['border-focus'] ?? aliases.brand?.primary ?? '#006FFF')
|
|
36
|
+
: 'transparent';
|
|
37
|
+
const placeholderColor = fieldTokens?.placeholder ?? aliases.text?.tertiary ?? '#757B80';
|
|
38
|
+
const textColor = fieldTokens?.['text-default'] ?? aliases.text?.primary ?? '#17191A';
|
|
39
|
+
const handleChange = (text) => {
|
|
40
|
+
setInternalValue(text);
|
|
41
|
+
onChangeText?.(text);
|
|
42
|
+
};
|
|
43
|
+
const handleClear = () => {
|
|
44
|
+
setInternalValue('');
|
|
45
|
+
onChangeText?.('');
|
|
46
|
+
onClear?.();
|
|
47
|
+
};
|
|
48
|
+
return (_jsxs(View, { style: [
|
|
49
|
+
styles.container,
|
|
50
|
+
{
|
|
51
|
+
height: sizeConfig.height, borderRadius: sizeConfig.height / 2,
|
|
52
|
+
backgroundColor: bgColor, paddingHorizontal: sizeConfig.paddingH,
|
|
53
|
+
borderWidth: isFocused ? 2 : 0, borderColor,
|
|
54
|
+
},
|
|
55
|
+
disabled && { opacity: disabledOpacity }, style,
|
|
56
|
+
], children: [startIcon ?? _jsx(Text, { style: { fontSize: sizeConfig.fontSize, color: placeholderColor }, children: "\uD83D\uDD0D" }), _jsx(TextInput, { value: currentValue, onChangeText: handleChange, onSubmitEditing: () => onSubmit?.(currentValue), placeholder: placeholder, placeholderTextColor: placeholderColor, editable: !disabled, onFocus: () => setIsFocused(true), onBlur: () => setIsFocused(false), returnKeyType: "search", style: [styles.input, { fontSize: sizeConfig.fontSize, color: textColor }], accessibilityLabel: placeholder }), showClearButton && currentValue.length > 0 && (_jsx(Pressable, { onPress: handleClear, hitSlop: 8, accessibilityLabel: "\uAC80\uC0C9 \uC9C0\uC6B0\uAE30", children: _jsx(Text, { style: { fontSize: sizeConfig.fontSize, color: aliases.text?.tertiary ?? '#757B80' }, children: "\u2715" }) }))] }));
|
|
57
|
+
};
|
|
58
|
+
SearchBar.displayName = 'SearchBar';
|
|
59
|
+
const styles = StyleSheet.create({
|
|
60
|
+
container: { flexDirection: 'row', alignItems: 'center', gap: 8 },
|
|
61
|
+
input: { flex: 1, height: '100%', padding: 0 },
|
|
62
|
+
});
|
|
63
|
+
export default SearchBar;
|
|
64
|
+
//# sourceMappingURL=SearchBar.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SearchBar.js","sourceRoot":"","sources":["../../../src/components/SearchBar/SearchBar.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/SearchBar/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AACxC,YAAY,EAAE,cAAc,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/SearchBar/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Skeleton 컴포넌트 (React Native)
|
|
3
|
+
*
|
|
4
|
+
* 스타일링 토큰 경로:
|
|
5
|
+
* - 배경: theme.color.aliases.surface.{layer-1|layer-2}
|
|
6
|
+
* - 라운드: theme.border.semantic.radius.{s|m|l}
|
|
7
|
+
*/
|
|
8
|
+
import React from 'react';
|
|
9
|
+
import { type ViewStyle } from 'react-native';
|
|
10
|
+
export type SkeletonVariant = 'text' | 'rectangular' | 'circular';
|
|
11
|
+
export interface SkeletonProps {
|
|
12
|
+
width?: number | string;
|
|
13
|
+
height?: number | string;
|
|
14
|
+
variant?: SkeletonVariant;
|
|
15
|
+
borderRadius?: number;
|
|
16
|
+
count?: number;
|
|
17
|
+
gap?: number;
|
|
18
|
+
style?: ViewStyle;
|
|
19
|
+
}
|
|
20
|
+
export declare const Skeleton: React.FC<SkeletonProps>;
|
|
21
|
+
export default Skeleton;
|
|
22
|
+
//# sourceMappingURL=Skeleton.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Skeleton.d.ts","sourceRoot":"","sources":["../../../src/components/Skeleton/Skeleton.tsx"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,KAA4B,MAAM,OAAO,CAAC;AACjD,OAAO,EAA8B,KAAK,SAAS,EAAE,MAAM,cAAc,CAAC;AAG1E,MAAM,MAAM,eAAe,GAAG,MAAM,GAAG,aAAa,GAAG,UAAU,CAAC;AAElE,MAAM,WAAW,aAAa;IAC1B,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACxB,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACzB,OAAO,CAAC,EAAE,eAAe,CAAC;IAC1B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,KAAK,CAAC,EAAE,SAAS,CAAC;CACrB;AAED,eAAO,MAAM,QAAQ,EAAE,KAAK,CAAC,EAAE,CAAC,aAAa,CA8C5C,CAAC;AAGF,eAAe,QAAQ,CAAC"}
|
|
@@ -0,0 +1,46 @@
|
|
|
1
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
2
|
+
/**
|
|
3
|
+
* Skeleton 컴포넌트 (React Native)
|
|
4
|
+
*
|
|
5
|
+
* 스타일링 토큰 경로:
|
|
6
|
+
* - 배경: theme.color.aliases.surface.{layer-1|layer-2}
|
|
7
|
+
* - 라운드: theme.border.semantic.radius.{s|m|l}
|
|
8
|
+
*/
|
|
9
|
+
import { useRef, useEffect } from 'react';
|
|
10
|
+
import { View, Animated } from 'react-native';
|
|
11
|
+
import { useTheme } from '../../theme/useTheme';
|
|
12
|
+
export const Skeleton = ({ width = '100%', height = 16, variant = 'text', borderRadius: customRadius, count = 1, gap: customGap, style, }) => {
|
|
13
|
+
const { theme } = useTheme();
|
|
14
|
+
const animValue = useRef(new Animated.Value(0)).current;
|
|
15
|
+
const surface = theme.color.aliases?.surface ?? {};
|
|
16
|
+
const radiusTokens = theme.border.semantic?.radius ?? {};
|
|
17
|
+
const gapValue = customGap ?? theme.spacing.aliases?.gap?.s ?? 8;
|
|
18
|
+
const bgColor = surface['layer-1'] ?? '#F2F8FC';
|
|
19
|
+
const pulseColor = surface['layer-2'] ?? '#E8EEF2';
|
|
20
|
+
const resolvedRadius = customRadius ?? (() => {
|
|
21
|
+
switch (variant) {
|
|
22
|
+
case 'circular': return typeof width === 'number' ? width / 2 : 9999;
|
|
23
|
+
case 'rectangular': return radiusTokens.s ?? 4;
|
|
24
|
+
default: return radiusTokens.s ?? 4;
|
|
25
|
+
}
|
|
26
|
+
})();
|
|
27
|
+
const resolvedSize = variant === 'circular' ? { width: width ?? 40, height: width ?? 40 } : { width, height };
|
|
28
|
+
useEffect(() => {
|
|
29
|
+
const animation = Animated.loop(Animated.sequence([
|
|
30
|
+
Animated.timing(animValue, { toValue: 1, duration: 800, useNativeDriver: false }),
|
|
31
|
+
Animated.timing(animValue, { toValue: 0, duration: 800, useNativeDriver: false }),
|
|
32
|
+
]));
|
|
33
|
+
animation.start();
|
|
34
|
+
return () => animation.stop();
|
|
35
|
+
}, [animValue]);
|
|
36
|
+
const backgroundColor = animValue.interpolate({ inputRange: [0, 1], outputRange: [bgColor, pulseColor] });
|
|
37
|
+
const items = Array.from({ length: count }, (_, i) => (_jsx(Animated.View, { style: [
|
|
38
|
+
{ ...resolvedSize, borderRadius: resolvedRadius, backgroundColor },
|
|
39
|
+
i > 0 && { marginTop: gapValue },
|
|
40
|
+
style,
|
|
41
|
+
] }, i)));
|
|
42
|
+
return count === 1 ? items[0] : _jsx(View, { children: items });
|
|
43
|
+
};
|
|
44
|
+
Skeleton.displayName = 'Skeleton';
|
|
45
|
+
export default Skeleton;
|
|
46
|
+
//# sourceMappingURL=Skeleton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"Skeleton.js","sourceRoot":"","sources":["../../../src/components/Skeleton/Skeleton.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Skeleton/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC;AACtC,YAAY,EAAE,aAAa,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Skeleton/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,YAAY,CAAC"}
|