@kukkim/react-native-ui 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.
Files changed (321) hide show
  1. package/LICENSE +20 -0
  2. package/README.md +33 -0
  3. package/lib/module/assets/icons/arrow-down-to-line.svg +1 -0
  4. package/lib/module/assets/icons/arrow-down-wide-narrow.svg +1 -0
  5. package/lib/module/assets/icons/arrow-left.svg +1 -0
  6. package/lib/module/assets/icons/check.svg +1 -0
  7. package/lib/module/assets/icons/chevron-down.svg +1 -0
  8. package/lib/module/assets/icons/copy.svg +1 -0
  9. package/lib/module/assets/icons/rotate-cw.svg +1 -0
  10. package/lib/module/assets/icons/square-arrow-out-up-right.svg +1 -0
  11. package/lib/module/assets/icons/star-empty.svg +1 -0
  12. package/lib/module/assets/icons/star-full.svg +1 -0
  13. package/lib/module/assets/icons/star-half.svg +25 -0
  14. package/lib/module/assets/icons/x.svg +1 -0
  15. package/lib/module/assets/images/defaultImage.png +0 -0
  16. package/lib/module/components/avatar/index.js +45 -0
  17. package/lib/module/components/avatar/index.js.map +1 -0
  18. package/lib/module/components/avatar/types.js +49 -0
  19. package/lib/module/components/avatar/types.js.map +1 -0
  20. package/lib/module/components/badge/commonBadge.js +44 -0
  21. package/lib/module/components/badge/commonBadge.js.map +1 -0
  22. package/lib/module/components/badge/index.js +5 -0
  23. package/lib/module/components/badge/index.js.map +1 -0
  24. package/lib/module/components/badge/types.js +48 -0
  25. package/lib/module/components/badge/types.js.map +1 -0
  26. package/lib/module/components/button/commonButton.js +43 -0
  27. package/lib/module/components/button/commonButton.js.map +1 -0
  28. package/lib/module/components/button/index.js +5 -0
  29. package/lib/module/components/button/index.js.map +1 -0
  30. package/lib/module/components/button/types.js +28 -0
  31. package/lib/module/components/button/types.js.map +1 -0
  32. package/lib/module/components/card/commonCard.js +57 -0
  33. package/lib/module/components/card/commonCard.js.map +1 -0
  34. package/lib/module/components/card/foldableCard.js +76 -0
  35. package/lib/module/components/card/foldableCard.js.map +1 -0
  36. package/lib/module/components/card/index.js +6 -0
  37. package/lib/module/components/card/index.js.map +1 -0
  38. package/lib/module/components/card/types.js +4 -0
  39. package/lib/module/components/card/types.js.map +1 -0
  40. package/lib/module/components/checkBox/index.js +38 -0
  41. package/lib/module/components/checkBox/index.js.map +1 -0
  42. package/lib/module/components/checkBox/types.js +17 -0
  43. package/lib/module/components/checkBox/types.js.map +1 -0
  44. package/lib/module/components/header/commonHeader.js +72 -0
  45. package/lib/module/components/header/commonHeader.js.map +1 -0
  46. package/lib/module/components/header/index.js +5 -0
  47. package/lib/module/components/header/index.js.map +1 -0
  48. package/lib/module/components/header/types.js +28 -0
  49. package/lib/module/components/header/types.js.map +1 -0
  50. package/lib/module/components/icon/ArrowDownToLine.js +25 -0
  51. package/lib/module/components/icon/ArrowDownToLine.js.map +1 -0
  52. package/lib/module/components/icon/ArrowDownWideNarrow.js +25 -0
  53. package/lib/module/components/icon/ArrowDownWideNarrow.js.map +1 -0
  54. package/lib/module/components/icon/ArrowLeft.js +25 -0
  55. package/lib/module/components/icon/ArrowLeft.js.map +1 -0
  56. package/lib/module/components/icon/Check.js +25 -0
  57. package/lib/module/components/icon/Check.js.map +1 -0
  58. package/lib/module/components/icon/ChevronDown.js +25 -0
  59. package/lib/module/components/icon/ChevronDown.js.map +1 -0
  60. package/lib/module/components/icon/Copy.js +32 -0
  61. package/lib/module/components/icon/Copy.js.map +1 -0
  62. package/lib/module/components/icon/RotateCw.js +27 -0
  63. package/lib/module/components/icon/RotateCw.js.map +1 -0
  64. package/lib/module/components/icon/SquareArrowOutUpRight.js +25 -0
  65. package/lib/module/components/icon/SquareArrowOutUpRight.js.map +1 -0
  66. package/lib/module/components/icon/StarEmpty.js +25 -0
  67. package/lib/module/components/icon/StarEmpty.js.map +1 -0
  68. package/lib/module/components/icon/StarFull.js +25 -0
  69. package/lib/module/components/icon/StarFull.js.map +1 -0
  70. package/lib/module/components/icon/StarHalf.js +34 -0
  71. package/lib/module/components/icon/StarHalf.js.map +1 -0
  72. package/lib/module/components/icon/X.js +25 -0
  73. package/lib/module/components/icon/X.js.map +1 -0
  74. package/lib/module/components/icon/index.js +54 -0
  75. package/lib/module/components/icon/index.js.map +1 -0
  76. package/lib/module/components/icon/types.js +8 -0
  77. package/lib/module/components/icon/types.js.map +1 -0
  78. package/lib/module/components/image/index.js +25 -0
  79. package/lib/module/components/image/index.js.map +1 -0
  80. package/lib/module/components/image/types.js +39 -0
  81. package/lib/module/components/image/types.js.map +1 -0
  82. package/lib/module/components/index.js +15 -0
  83. package/lib/module/components/index.js.map +1 -0
  84. package/lib/module/components/progressBar/circularProgressBar.js +59 -0
  85. package/lib/module/components/progressBar/circularProgressBar.js.map +1 -0
  86. package/lib/module/components/progressBar/index.js +7 -0
  87. package/lib/module/components/progressBar/index.js.map +1 -0
  88. package/lib/module/components/progressBar/linearProgressBar.js +42 -0
  89. package/lib/module/components/progressBar/linearProgressBar.js.map +1 -0
  90. package/lib/module/components/progressBar/types.js +13 -0
  91. package/lib/module/components/progressBar/types.js.map +1 -0
  92. package/lib/module/components/rating/index.js +84 -0
  93. package/lib/module/components/rating/index.js.map +1 -0
  94. package/lib/module/components/rating/types.js +8 -0
  95. package/lib/module/components/rating/types.js.map +1 -0
  96. package/lib/module/components/screenContainer/SafeAreaContainer.js +26 -0
  97. package/lib/module/components/screenContainer/SafeAreaContainer.js.map +1 -0
  98. package/lib/module/components/screenContainer/ScrollViewContainer.js +24 -0
  99. package/lib/module/components/screenContainer/ScrollViewContainer.js.map +1 -0
  100. package/lib/module/components/screenContainer/index.js +6 -0
  101. package/lib/module/components/screenContainer/index.js.map +1 -0
  102. package/lib/module/components/skeleton/index.js +3 -0
  103. package/lib/module/components/skeleton/index.js.map +1 -0
  104. package/lib/module/components/skeleton/types.js +2 -0
  105. package/lib/module/components/skeleton/types.js.map +1 -0
  106. package/lib/module/components/slider/index.js +3 -0
  107. package/lib/module/components/slider/index.js.map +1 -0
  108. package/lib/module/components/slider/types.js +2 -0
  109. package/lib/module/components/slider/types.js.map +1 -0
  110. package/lib/module/components/switch/index.js +3 -0
  111. package/lib/module/components/switch/index.js.map +1 -0
  112. package/lib/module/components/switch/types.js +2 -0
  113. package/lib/module/components/switch/types.js.map +1 -0
  114. package/lib/module/components/text/commonText.js +28 -0
  115. package/lib/module/components/text/commonText.js.map +1 -0
  116. package/lib/module/components/text/index.js +5 -0
  117. package/lib/module/components/text/index.js.map +1 -0
  118. package/lib/module/components/text/types.js +17 -0
  119. package/lib/module/components/text/types.js.map +1 -0
  120. package/lib/module/hooks/useTheme.js +12 -0
  121. package/lib/module/hooks/useTheme.js.map +1 -0
  122. package/lib/module/index.js +5 -0
  123. package/lib/module/index.js.map +1 -0
  124. package/lib/module/package.json +1 -0
  125. package/lib/module/theme/color.js +10 -0
  126. package/lib/module/theme/color.js.map +1 -0
  127. package/lib/module/theme/style.js +17 -0
  128. package/lib/module/theme/style.js.map +1 -0
  129. package/lib/module/theme/themeProvider.js +22 -0
  130. package/lib/module/theme/themeProvider.js.map +1 -0
  131. package/lib/module/theme/themes.js +41 -0
  132. package/lib/module/theme/themes.js.map +1 -0
  133. package/lib/typescript/package.json +1 -0
  134. package/lib/typescript/src/components/avatar/index.d.ts +3 -0
  135. package/lib/typescript/src/components/avatar/index.d.ts.map +1 -0
  136. package/lib/typescript/src/components/avatar/types.d.ts +16 -0
  137. package/lib/typescript/src/components/avatar/types.d.ts.map +1 -0
  138. package/lib/typescript/src/components/badge/commonBadge.d.ts +4 -0
  139. package/lib/typescript/src/components/badge/commonBadge.d.ts.map +1 -0
  140. package/lib/typescript/src/components/badge/index.d.ts +3 -0
  141. package/lib/typescript/src/components/badge/index.d.ts.map +1 -0
  142. package/lib/typescript/src/components/badge/types.d.ts +19 -0
  143. package/lib/typescript/src/components/badge/types.d.ts.map +1 -0
  144. package/lib/typescript/src/components/button/commonButton.d.ts +4 -0
  145. package/lib/typescript/src/components/button/commonButton.d.ts.map +1 -0
  146. package/lib/typescript/src/components/button/index.d.ts +3 -0
  147. package/lib/typescript/src/components/button/index.d.ts.map +1 -0
  148. package/lib/typescript/src/components/button/types.d.ts +14 -0
  149. package/lib/typescript/src/components/button/types.d.ts.map +1 -0
  150. package/lib/typescript/src/components/card/commonCard.d.ts +4 -0
  151. package/lib/typescript/src/components/card/commonCard.d.ts.map +1 -0
  152. package/lib/typescript/src/components/card/foldableCard.d.ts +4 -0
  153. package/lib/typescript/src/components/card/foldableCard.d.ts.map +1 -0
  154. package/lib/typescript/src/components/card/index.d.ts +4 -0
  155. package/lib/typescript/src/components/card/index.d.ts.map +1 -0
  156. package/lib/typescript/src/components/card/types.d.ts +16 -0
  157. package/lib/typescript/src/components/card/types.d.ts.map +1 -0
  158. package/lib/typescript/src/components/checkBox/index.d.ts +3 -0
  159. package/lib/typescript/src/components/checkBox/index.d.ts.map +1 -0
  160. package/lib/typescript/src/components/checkBox/types.d.ts +11 -0
  161. package/lib/typescript/src/components/checkBox/types.d.ts.map +1 -0
  162. package/lib/typescript/src/components/header/commonHeader.d.ts +4 -0
  163. package/lib/typescript/src/components/header/commonHeader.d.ts.map +1 -0
  164. package/lib/typescript/src/components/header/index.d.ts +3 -0
  165. package/lib/typescript/src/components/header/index.d.ts.map +1 -0
  166. package/lib/typescript/src/components/header/types.d.ts +19 -0
  167. package/lib/typescript/src/components/header/types.d.ts.map +1 -0
  168. package/lib/typescript/src/components/icon/ArrowDownToLine.d.ts +4 -0
  169. package/lib/typescript/src/components/icon/ArrowDownToLine.d.ts.map +1 -0
  170. package/lib/typescript/src/components/icon/ArrowDownWideNarrow.d.ts +4 -0
  171. package/lib/typescript/src/components/icon/ArrowDownWideNarrow.d.ts.map +1 -0
  172. package/lib/typescript/src/components/icon/ArrowLeft.d.ts +4 -0
  173. package/lib/typescript/src/components/icon/ArrowLeft.d.ts.map +1 -0
  174. package/lib/typescript/src/components/icon/Check.d.ts +4 -0
  175. package/lib/typescript/src/components/icon/Check.d.ts.map +1 -0
  176. package/lib/typescript/src/components/icon/ChevronDown.d.ts +4 -0
  177. package/lib/typescript/src/components/icon/ChevronDown.d.ts.map +1 -0
  178. package/lib/typescript/src/components/icon/Copy.d.ts +4 -0
  179. package/lib/typescript/src/components/icon/Copy.d.ts.map +1 -0
  180. package/lib/typescript/src/components/icon/RotateCw.d.ts +4 -0
  181. package/lib/typescript/src/components/icon/RotateCw.d.ts.map +1 -0
  182. package/lib/typescript/src/components/icon/SquareArrowOutUpRight.d.ts +4 -0
  183. package/lib/typescript/src/components/icon/SquareArrowOutUpRight.d.ts.map +1 -0
  184. package/lib/typescript/src/components/icon/StarEmpty.d.ts +4 -0
  185. package/lib/typescript/src/components/icon/StarEmpty.d.ts.map +1 -0
  186. package/lib/typescript/src/components/icon/StarFull.d.ts +4 -0
  187. package/lib/typescript/src/components/icon/StarFull.d.ts.map +1 -0
  188. package/lib/typescript/src/components/icon/StarHalf.d.ts +4 -0
  189. package/lib/typescript/src/components/icon/StarHalf.d.ts.map +1 -0
  190. package/lib/typescript/src/components/icon/X.d.ts +4 -0
  191. package/lib/typescript/src/components/icon/X.d.ts.map +1 -0
  192. package/lib/typescript/src/components/icon/index.d.ts +3 -0
  193. package/lib/typescript/src/components/icon/index.d.ts.map +1 -0
  194. package/lib/typescript/src/components/icon/types.d.ts +12 -0
  195. package/lib/typescript/src/components/icon/types.d.ts.map +1 -0
  196. package/lib/typescript/src/components/image/index.d.ts +3 -0
  197. package/lib/typescript/src/components/image/index.d.ts.map +1 -0
  198. package/lib/typescript/src/components/image/types.d.ts +9 -0
  199. package/lib/typescript/src/components/image/types.d.ts.map +1 -0
  200. package/lib/typescript/src/components/index.d.ts +13 -0
  201. package/lib/typescript/src/components/index.d.ts.map +1 -0
  202. package/lib/typescript/src/components/progressBar/circularProgressBar.d.ts +4 -0
  203. package/lib/typescript/src/components/progressBar/circularProgressBar.d.ts.map +1 -0
  204. package/lib/typescript/src/components/progressBar/index.d.ts +4 -0
  205. package/lib/typescript/src/components/progressBar/index.d.ts.map +1 -0
  206. package/lib/typescript/src/components/progressBar/linearProgressBar.d.ts +4 -0
  207. package/lib/typescript/src/components/progressBar/linearProgressBar.d.ts.map +1 -0
  208. package/lib/typescript/src/components/progressBar/types.d.ts +12 -0
  209. package/lib/typescript/src/components/progressBar/types.d.ts.map +1 -0
  210. package/lib/typescript/src/components/rating/index.d.ts +3 -0
  211. package/lib/typescript/src/components/rating/index.d.ts.map +1 -0
  212. package/lib/typescript/src/components/rating/types.d.ts +13 -0
  213. package/lib/typescript/src/components/rating/types.d.ts.map +1 -0
  214. package/lib/typescript/src/components/screenContainer/SafeAreaContainer.d.ts +4 -0
  215. package/lib/typescript/src/components/screenContainer/SafeAreaContainer.d.ts.map +1 -0
  216. package/lib/typescript/src/components/screenContainer/ScrollViewContainer.d.ts +4 -0
  217. package/lib/typescript/src/components/screenContainer/ScrollViewContainer.d.ts.map +1 -0
  218. package/lib/typescript/src/components/screenContainer/index.d.ts +4 -0
  219. package/lib/typescript/src/components/screenContainer/index.d.ts.map +1 -0
  220. package/lib/typescript/src/components/skeleton/index.d.ts +1 -0
  221. package/lib/typescript/src/components/skeleton/index.d.ts.map +1 -0
  222. package/lib/typescript/src/components/skeleton/types.d.ts +1 -0
  223. package/lib/typescript/src/components/skeleton/types.d.ts.map +1 -0
  224. package/lib/typescript/src/components/slider/index.d.ts +1 -0
  225. package/lib/typescript/src/components/slider/index.d.ts.map +1 -0
  226. package/lib/typescript/src/components/slider/types.d.ts +1 -0
  227. package/lib/typescript/src/components/slider/types.d.ts.map +1 -0
  228. package/lib/typescript/src/components/switch/index.d.ts +1 -0
  229. package/lib/typescript/src/components/switch/index.d.ts.map +1 -0
  230. package/lib/typescript/src/components/switch/types.d.ts +1 -0
  231. package/lib/typescript/src/components/switch/types.d.ts.map +1 -0
  232. package/lib/typescript/src/components/text/commonText.d.ts +4 -0
  233. package/lib/typescript/src/components/text/commonText.d.ts.map +1 -0
  234. package/lib/typescript/src/components/text/index.d.ts +3 -0
  235. package/lib/typescript/src/components/text/index.d.ts.map +1 -0
  236. package/lib/typescript/src/components/text/types.d.ts +11 -0
  237. package/lib/typescript/src/components/text/types.d.ts.map +1 -0
  238. package/lib/typescript/src/hooks/useTheme.d.ts +5 -0
  239. package/lib/typescript/src/hooks/useTheme.d.ts.map +1 -0
  240. package/lib/typescript/src/index.d.ts +3 -0
  241. package/lib/typescript/src/index.d.ts.map +1 -0
  242. package/lib/typescript/src/theme/color.d.ts +8 -0
  243. package/lib/typescript/src/theme/color.d.ts.map +1 -0
  244. package/lib/typescript/src/theme/style.d.ts +15 -0
  245. package/lib/typescript/src/theme/style.d.ts.map +1 -0
  246. package/lib/typescript/src/theme/themeProvider.d.ts +13 -0
  247. package/lib/typescript/src/theme/themeProvider.d.ts.map +1 -0
  248. package/lib/typescript/src/theme/themes.d.ts +25 -0
  249. package/lib/typescript/src/theme/themes.d.ts.map +1 -0
  250. package/package.json +170 -0
  251. package/src/assets/icons/arrow-down-to-line.svg +1 -0
  252. package/src/assets/icons/arrow-down-wide-narrow.svg +1 -0
  253. package/src/assets/icons/arrow-left.svg +1 -0
  254. package/src/assets/icons/check.svg +1 -0
  255. package/src/assets/icons/chevron-down.svg +1 -0
  256. package/src/assets/icons/copy.svg +1 -0
  257. package/src/assets/icons/rotate-cw.svg +1 -0
  258. package/src/assets/icons/square-arrow-out-up-right.svg +1 -0
  259. package/src/assets/icons/star-empty.svg +1 -0
  260. package/src/assets/icons/star-full.svg +1 -0
  261. package/src/assets/icons/star-half.svg +25 -0
  262. package/src/assets/icons/x.svg +1 -0
  263. package/src/assets/images/defaultImage.png +0 -0
  264. package/src/components/avatar/index.tsx +58 -0
  265. package/src/components/avatar/types.ts +38 -0
  266. package/src/components/badge/commonBadge.tsx +50 -0
  267. package/src/components/badge/index.ts +3 -0
  268. package/src/components/badge/types.ts +36 -0
  269. package/src/components/button/commonButton.tsx +43 -0
  270. package/src/components/button/index.ts +3 -0
  271. package/src/components/button/types.ts +29 -0
  272. package/src/components/card/commonCard.tsx +67 -0
  273. package/src/components/card/foldableCard.tsx +88 -0
  274. package/src/components/card/index.ts +4 -0
  275. package/src/components/card/types.ts +18 -0
  276. package/src/components/checkBox/index.tsx +41 -0
  277. package/src/components/checkBox/types.ts +16 -0
  278. package/src/components/header/commonHeader.tsx +55 -0
  279. package/src/components/header/index.ts +3 -0
  280. package/src/components/header/types.ts +30 -0
  281. package/src/components/icon/ArrowDownToLine.tsx +21 -0
  282. package/src/components/icon/ArrowDownWideNarrow.tsx +21 -0
  283. package/src/components/icon/ArrowLeft.tsx +21 -0
  284. package/src/components/icon/Check.tsx +21 -0
  285. package/src/components/icon/ChevronDown.tsx +21 -0
  286. package/src/components/icon/Copy.tsx +22 -0
  287. package/src/components/icon/RotateCw.tsx +22 -0
  288. package/src/components/icon/SquareArrowOutUpRight.tsx +21 -0
  289. package/src/components/icon/StarEmpty.tsx +21 -0
  290. package/src/components/icon/StarFull.tsx +21 -0
  291. package/src/components/icon/StarHalf.tsx +32 -0
  292. package/src/components/icon/X.tsx +21 -0
  293. package/src/components/icon/index.tsx +54 -0
  294. package/src/components/icon/types.ts +30 -0
  295. package/src/components/image/index.tsx +21 -0
  296. package/src/components/image/types.ts +20 -0
  297. package/src/components/index.ts +12 -0
  298. package/src/components/progressBar/circularProgressBar.tsx +64 -0
  299. package/src/components/progressBar/index.ts +5 -0
  300. package/src/components/progressBar/linearProgressBar.tsx +51 -0
  301. package/src/components/progressBar/types.ts +22 -0
  302. package/src/components/rating/index.tsx +106 -0
  303. package/src/components/rating/types.ts +17 -0
  304. package/src/components/screenContainer/SafeAreaContainer.tsx +22 -0
  305. package/src/components/screenContainer/ScrollViewContainer.tsx +19 -0
  306. package/src/components/screenContainer/index.ts +4 -0
  307. package/src/components/skeleton/index.tsx +1 -0
  308. package/src/components/skeleton/types.ts +0 -0
  309. package/src/components/slider/index.tsx +1 -0
  310. package/src/components/slider/types.ts +0 -0
  311. package/src/components/switch/index.tsx +1 -0
  312. package/src/components/switch/types.ts +0 -0
  313. package/src/components/text/commonText.tsx +27 -0
  314. package/src/components/text/index.ts +3 -0
  315. package/src/components/text/types.ts +16 -0
  316. package/src/hooks/useTheme.ts +12 -0
  317. package/src/index.tsx +18 -0
  318. package/src/theme/color.ts +7 -0
  319. package/src/theme/style.ts +15 -0
  320. package/src/theme/themeProvider.tsx +25 -0
  321. package/src/theme/themes.ts +71 -0
@@ -0,0 +1,54 @@
1
+ import { StyleSheet, View } from 'react-native';
2
+ import { type IconProps, sizeType } from './types';
3
+ // import { useTheme } from '../../hooks/useTheme';
4
+ import ArrowLeft from './ArrowLeft';
5
+ import StarEmpty from './StarEmpty';
6
+ import StarHalf from './StarHalf';
7
+ import StarFull from './StarFull';
8
+ import Check from './Check';
9
+ import X from './X';
10
+ // import { ArrowDownToLine } from './ArrowDownToLine';
11
+ // import { ArrowDownWideNarrow } from './ArrowDownWideNarrow';
12
+ // import { ChevronDown } from './ChevronDown';
13
+ // import { RotateCw } from './RotateCw';
14
+ // export { SquareArrowOutUpRight } from './SquareArrowOutUpRight';
15
+
16
+ const iconMap = {
17
+ back: ArrowLeft,
18
+ star_empty: StarEmpty,
19
+ star_half: StarHalf,
20
+ star_full: StarFull,
21
+ check: Check,
22
+ close: X,
23
+ } as const;
24
+
25
+ export const CommonIcon = ({
26
+ iconType,
27
+ size = 'm',
28
+ color = 'black',
29
+ ...props
30
+ }: IconProps) => {
31
+ // const { theme } = useTheme();
32
+
33
+ const IconComponent = iconMap[iconType];
34
+ if (!IconComponent) {
35
+ return null;
36
+ }
37
+
38
+ return (
39
+ <View style={styles.container} {...props}>
40
+ <IconComponent
41
+ width={sizeType[size]}
42
+ height={sizeType[size]}
43
+ color={color}
44
+ />
45
+ </View>
46
+ );
47
+ };
48
+
49
+ const styles = StyleSheet.create({
50
+ container: {
51
+ // margin: 5,
52
+ // padding: 5,
53
+ },
54
+ });
@@ -0,0 +1,30 @@
1
+ import { type ViewProps } from 'react-native';
2
+
3
+ type Variant = 'primary' | 'secondary';
4
+ type SizeVariant = 's' | 'm' | 'l';
5
+
6
+ export const sizeType: Record<SizeVariant, number> = {
7
+ s: 20,
8
+ m: 24,
9
+ l: 28,
10
+ };
11
+
12
+ export interface IconProps extends ViewProps {
13
+ iconType: // | 'setting'
14
+ // | 'search'
15
+ // | 'spinner'
16
+ | 'check'
17
+ | 'back'
18
+ | 'close'
19
+ // | 'apple'
20
+ // | 'facebook'
21
+ // | 'google'
22
+ // | 'close'
23
+ // | 'tune'
24
+ | 'star_empty'
25
+ | 'star_half'
26
+ | 'star_full';
27
+ type?: Variant;
28
+ size?: SizeVariant;
29
+ color?: string;
30
+ }
@@ -0,0 +1,21 @@
1
+ // import { useState } from 'react';
2
+ import { Image, StyleSheet } from 'react-native';
3
+ import { type CommonImageProps, sizeType } from './types';
4
+
5
+ export const CommonImage = ({ size = 'm', ...props }: CommonImageProps) => {
6
+ // const [loading, setLoading] = useState(true);
7
+ return (
8
+ <Image
9
+ style={[styles.container, sizeType[size]]}
10
+ source={require('../../assets/images/defaultImage.png')}
11
+ // onLoad={({ nativeEvent }) => {
12
+ // setLoading(false);
13
+ // }}
14
+ {...props}
15
+ />
16
+ );
17
+ };
18
+
19
+ const styles = StyleSheet.create({
20
+ container: {},
21
+ });
@@ -0,0 +1,20 @@
1
+ import { type ImageProps, type ImageStyle } from 'react-native';
2
+
3
+ // type Variant = 'primary' | 'secondary';
4
+ type SizeVariant = 's' | 'm' | 'l';
5
+
6
+ export const sizeType: Record<SizeVariant, ImageStyle> = {
7
+ s: { width: 24, height: 24 },
8
+ m: { width: 48, height: 48 },
9
+ l: { width: 72, height: 72 },
10
+ };
11
+
12
+ export const avatarSizeType: Record<SizeVariant, ImageStyle> = {
13
+ s: { width: 24, height: 24, borderRadius: 12, borderWidth: 1 },
14
+ m: { width: 48, height: 48, borderRadius: 24, borderWidth: 1 },
15
+ l: { width: 72, height: 72, borderRadius: 36, borderWidth: 1 },
16
+ };
17
+
18
+ export interface CommonImageProps extends ImageProps {
19
+ size?: SizeVariant;
20
+ }
@@ -0,0 +1,12 @@
1
+ export { CommonText } from './text';
2
+ export { CommonButton } from './button';
3
+ export { CommonBadge } from './badge';
4
+ export { SafeAreaContainer, ScrollViewContainer } from './screenContainer';
5
+ export { CommonIcon } from './icon';
6
+ export { CommonRating } from './rating';
7
+ export { CommonAvatar } from './avatar';
8
+ export { CommonImage } from './image';
9
+ export { CheckBox } from './checkBox';
10
+ export { CommonHeader } from './header';
11
+ export { CommonCard, FoldableCard } from './card';
12
+ export { LinearProgressBar, CircularProgressBar } from './progressBar';
@@ -0,0 +1,64 @@
1
+ import { StyleSheet, View } from 'react-native';
2
+ import Svg, { Circle } from 'react-native-svg';
3
+ import { type ProgressBarProps, sizeType, strokeWidthType } from './types';
4
+ import { useTheme } from '../../hooks/useTheme';
5
+
6
+ const CircularProgressBar = ({
7
+ type = 'primary',
8
+ size = 'm',
9
+ value,
10
+ style,
11
+ ...props
12
+ }: ProgressBarProps) => {
13
+ const { theme } = useTheme();
14
+
15
+ const progress = Math.min(Math.max(value, 0), 1);
16
+
17
+ const svgSize = sizeType[size];
18
+ const strokeWidth = strokeWidthType[size];
19
+
20
+ const radius = (svgSize - strokeWidth) / 2;
21
+ const circumference = 2 * Math.PI * radius;
22
+
23
+ const strokeDashoffset = circumference * (1 - progress);
24
+
25
+ return (
26
+ <View style={[styles.container, style]} {...props}>
27
+ <Svg
28
+ width={svgSize}
29
+ height={svgSize}
30
+ viewBox={`0 0 ${svgSize} ${svgSize}`}
31
+ >
32
+ <Circle
33
+ cx={svgSize / 2}
34
+ cy={svgSize / 2}
35
+ r={radius}
36
+ stroke={theme.colors.disabled}
37
+ strokeWidth={strokeWidth}
38
+ fill="none"
39
+ />
40
+
41
+ <Circle
42
+ cx={svgSize / 2}
43
+ cy={svgSize / 2}
44
+ r={radius}
45
+ stroke={theme.colors[type]}
46
+ strokeWidth={strokeWidth}
47
+ fill="none"
48
+ strokeLinecap="round"
49
+ strokeDasharray={circumference}
50
+ strokeDashoffset={strokeDashoffset}
51
+ rotation="-90"
52
+ originX={svgSize / 2}
53
+ originY={svgSize / 2}
54
+ />
55
+ </Svg>
56
+ </View>
57
+ );
58
+ };
59
+
60
+ const styles = StyleSheet.create({
61
+ container: {},
62
+ });
63
+
64
+ export default CircularProgressBar;
@@ -0,0 +1,5 @@
1
+ // TODO: progressbar에 react-native-reanimated를 이용한 animation적용 필요.
2
+ import LinearProgressBar from './linearProgressBar';
3
+ import CircularProgressBar from './circularProgressBar';
4
+
5
+ export { LinearProgressBar, CircularProgressBar };
@@ -0,0 +1,51 @@
1
+ import { StyleSheet, View } from 'react-native';
2
+ import { type ProgressBarProps } from './types';
3
+ import { useTheme } from '../../hooks/useTheme';
4
+
5
+ const LinearProgressBar = ({
6
+ type = 'primary',
7
+ value,
8
+ style,
9
+ ...props
10
+ }: ProgressBarProps) => {
11
+ const { theme } = useTheme();
12
+ const progress = Math.min(Math.max(value, 0), 1);
13
+
14
+ return (
15
+ <View
16
+ style={[
17
+ styles.container,
18
+ {
19
+ backgroundColor: theme.colors.disabled,
20
+ },
21
+ style,
22
+ ]}
23
+ {...props}
24
+ >
25
+ <View
26
+ style={[
27
+ styles.progress,
28
+ {
29
+ width: `${progress * 100}%`,
30
+ backgroundColor: theme.colors[type],
31
+ },
32
+ ]}
33
+ />
34
+ </View>
35
+ );
36
+ };
37
+
38
+ const styles = StyleSheet.create({
39
+ container: {
40
+ width: '100%',
41
+ height: 8,
42
+ borderRadius: 999,
43
+ overflow: 'hidden',
44
+ },
45
+ progress: {
46
+ height: '100%',
47
+ borderRadius: 999,
48
+ },
49
+ });
50
+
51
+ export default LinearProgressBar;
@@ -0,0 +1,22 @@
1
+ import { type ViewProps } from 'react-native';
2
+
3
+ type Variant = 'primary' | 'secondary';
4
+ type SizeVariant = 's' | 'm' | 'l';
5
+
6
+ export const sizeType: Record<SizeVariant, number> = {
7
+ s: 32,
8
+ m: 48,
9
+ l: 60,
10
+ };
11
+
12
+ export const strokeWidthType: Record<SizeVariant, number> = {
13
+ s: 4,
14
+ m: 6,
15
+ l: 12,
16
+ };
17
+
18
+ export interface ProgressBarProps extends ViewProps {
19
+ type?: Variant;
20
+ size?: SizeVariant;
21
+ value: number;
22
+ }
@@ -0,0 +1,106 @@
1
+ import { Pressable, StyleSheet, View } from 'react-native';
2
+ import { CommonIcon } from '../icon';
3
+ import { useTheme } from '../../hooks/useTheme';
4
+ import { type RatingProps, sizeType } from './types';
5
+
6
+ export const CommonRating = ({
7
+ type = 'primary',
8
+ value,
9
+ onChange,
10
+ editable = false,
11
+ size = 'm',
12
+ maxRating = 5,
13
+ }: RatingProps) => {
14
+ const { theme } = useTheme();
15
+ const renderStar = (index: number) => {
16
+ const starNumber = index + 1;
17
+
18
+ let iconType: 'star_empty' | 'star_half' | 'star_full' = 'star_empty';
19
+
20
+ if (value >= starNumber) {
21
+ iconType = 'star_full';
22
+ } else if (value >= starNumber - 0.5) {
23
+ iconType = 'star_half';
24
+ }
25
+
26
+ if (!editable) {
27
+ return (
28
+ <View key={index}>
29
+ <CommonIcon
30
+ iconType={iconType}
31
+ size={size}
32
+ color={theme.colors[type]}
33
+ />
34
+ </View>
35
+ );
36
+ }
37
+
38
+ return (
39
+ <View
40
+ key={index}
41
+ style={[
42
+ {
43
+ width: sizeType[size],
44
+ height: sizeType[size],
45
+ },
46
+ styles.starContainer,
47
+ ]}
48
+ >
49
+ <CommonIcon
50
+ iconType={iconType}
51
+ size={size}
52
+ color={theme.colors[type]}
53
+ />
54
+
55
+ {/* 왼쪽 절반 */}
56
+ <Pressable
57
+ style={[
58
+ StyleSheet.absoluteFillObject,
59
+ {
60
+ width: sizeType[size] / 2,
61
+ },
62
+ styles.left,
63
+ ]}
64
+ onPress={() => {
65
+ onChange?.(index + 0.5);
66
+ }}
67
+ />
68
+
69
+ {/* 오른쪽 절반 */}
70
+ <Pressable
71
+ style={[
72
+ StyleSheet.absoluteFillObject,
73
+ {
74
+ width: sizeType[size] / 2,
75
+ left: sizeType[size] / 2,
76
+ },
77
+ ]}
78
+ onPress={() => {
79
+ onChange?.(index + 1);
80
+ }}
81
+ />
82
+ </View>
83
+ );
84
+ };
85
+
86
+ return (
87
+ <View style={styles.container}>
88
+ {Array.from({ length: maxRating }).map((_, index) => renderStar(index))}
89
+ </View>
90
+ );
91
+ };
92
+
93
+ const styles = StyleSheet.create({
94
+ container: {
95
+ flexDirection: 'row',
96
+ alignItems: 'center',
97
+ },
98
+ starContainer: {
99
+ position: 'relative',
100
+ justifyContent: 'center',
101
+ alignItems: 'center',
102
+ },
103
+ left: {
104
+ left: 0,
105
+ },
106
+ });
@@ -0,0 +1,17 @@
1
+ type Variant = 'primary' | 'secondary';
2
+ type SizeVariant = 's' | 'm' | 'l';
3
+
4
+ export const sizeType: Record<SizeVariant, number> = {
5
+ s: 20,
6
+ m: 24,
7
+ l: 28,
8
+ };
9
+
10
+ export interface RatingProps {
11
+ type?: Variant;
12
+ value: number;
13
+ onChange?: (rating: number) => void;
14
+ editable?: boolean;
15
+ size?: SizeVariant;
16
+ maxRating?: number;
17
+ }
@@ -0,0 +1,22 @@
1
+ import { useTheme } from '../../hooks/useTheme';
2
+ import { StyleSheet, type ViewProps } from 'react-native';
3
+ import { SafeAreaView } from 'react-native-safe-area-context';
4
+
5
+ const SafeAreaContainer = ({ children }: ViewProps) => {
6
+ const { theme } = useTheme();
7
+ return (
8
+ <SafeAreaView
9
+ style={[styles.container, { backgroundColor: theme.colors.background }]}
10
+ >
11
+ {children}
12
+ </SafeAreaView>
13
+ );
14
+ };
15
+
16
+ const styles = StyleSheet.create({
17
+ container: {
18
+ flex: 1,
19
+ },
20
+ });
21
+
22
+ export default SafeAreaContainer;
@@ -0,0 +1,19 @@
1
+ import { ScrollView, StyleSheet, type ViewProps } from 'react-native';
2
+ import SafeAreaContainer from './SafeAreaContainer';
3
+
4
+ //TODO : SafeAreaContainer가 적용되지 않음.
5
+ const ScrollViewContainer = ({ children }: ViewProps) => {
6
+ return (
7
+ <SafeAreaContainer>
8
+ <ScrollView style={[styles.container]}>{children}</ScrollView>
9
+ </SafeAreaContainer>
10
+ );
11
+ };
12
+
13
+ const styles = StyleSheet.create({
14
+ container: {
15
+ flex: 1,
16
+ },
17
+ });
18
+
19
+ export default ScrollViewContainer;
@@ -0,0 +1,4 @@
1
+ import SafeAreaContainer from './SafeAreaContainer';
2
+ import ScrollViewContainer from './ScrollViewContainer';
3
+
4
+ export { SafeAreaContainer, ScrollViewContainer };
@@ -0,0 +1 @@
1
+ // TODO: skeleton 구현 필요
File without changes
@@ -0,0 +1 @@
1
+ // TODO: slider 구현 필요
File without changes
@@ -0,0 +1 @@
1
+ // TODO: switch 구현 필요
File without changes
@@ -0,0 +1,27 @@
1
+ import { StyleSheet, Text } from 'react-native';
2
+ import { type CommonTextProps, fontSizeType } from './types';
3
+ import { useTheme } from '../../hooks/useTheme';
4
+
5
+ const CommonText = ({ size = 'm', children, style }: CommonTextProps) => {
6
+ const { theme } = useTheme();
7
+ return (
8
+ <Text
9
+ style={[
10
+ { color: theme.colors.text },
11
+ styles.innerText,
12
+ fontSizeType[size],
13
+ style,
14
+ ]}
15
+ >
16
+ {children}
17
+ </Text>
18
+ );
19
+ };
20
+
21
+ const styles = StyleSheet.create({
22
+ innerText: {
23
+ fontFamily: 'Roboto',
24
+ },
25
+ });
26
+
27
+ export default CommonText;
@@ -0,0 +1,3 @@
1
+ import CommonText from './commonText';
2
+
3
+ export { CommonText };
@@ -0,0 +1,16 @@
1
+ import { type TextProps, type TextStyle } from 'react-native';
2
+
3
+ type Variant = 'primary' | 'secondary';
4
+ type SizeVariant = 's' | 'm' | 'l';
5
+
6
+ export const fontSizeType: Record<SizeVariant, TextStyle> = {
7
+ s: { fontSize: 12, fontWeight: '600' },
8
+ m: { fontSize: 24, fontWeight: '700' },
9
+ l: { fontSize: 36, fontWeight: '900' },
10
+ };
11
+
12
+ export interface CommonTextProps extends TextProps {
13
+ type?: Variant;
14
+ size?: SizeVariant;
15
+ isInner?: boolean;
16
+ }
@@ -0,0 +1,12 @@
1
+ import { useContext } from 'react';
2
+ import { ThemeContext } from '../theme/themeProvider';
3
+
4
+ export function useTheme() {
5
+ const context = useContext(ThemeContext);
6
+
7
+ if (!context) {
8
+ throw new Error('useTheme must be used within ThemeProvider');
9
+ }
10
+
11
+ return context;
12
+ }
package/src/index.tsx ADDED
@@ -0,0 +1,18 @@
1
+ export {
2
+ CommonText,
3
+ CommonButton,
4
+ CommonBadge,
5
+ SafeAreaContainer,
6
+ ScrollViewContainer,
7
+ CommonIcon,
8
+ CommonRating,
9
+ CommonAvatar,
10
+ CommonImage,
11
+ CheckBox,
12
+ CommonHeader,
13
+ CommonCard,
14
+ FoldableCard,
15
+ LinearProgressBar,
16
+ CircularProgressBar,
17
+ } from './components';
18
+ export { ThemeProvider } from './theme/themeProvider';
@@ -0,0 +1,7 @@
1
+ export const palette = {
2
+ blue500: '#3478F6',
3
+ gray100: '#F5F5F5',
4
+ gray900: '#111111',
5
+ red500: '#FF3B30',
6
+ yellow500: '#FFCC00',
7
+ };
@@ -0,0 +1,15 @@
1
+ export const spacing = {
2
+ none: 0,
3
+ xs: 4,
4
+ sm: 8,
5
+ md: 12,
6
+ lg: 16,
7
+ xl: 24,
8
+ };
9
+
10
+ export const radius = {
11
+ sm: 4,
12
+ md: 8,
13
+ lg: 12,
14
+ full: 999,
15
+ };
@@ -0,0 +1,25 @@
1
+ import { createContext, type PropsWithChildren, useMemo } from 'react';
2
+ import { lightTheme, darkTheme, type AppTheme, type ThemeMode } from './themes';
3
+
4
+ type ThemeContextValue = {
5
+ theme: AppTheme;
6
+ mode: ThemeMode;
7
+ };
8
+
9
+ export const ThemeContext = createContext<ThemeContextValue | null>(null);
10
+
11
+ type Props = PropsWithChildren<{
12
+ mode?: ThemeMode;
13
+ }>;
14
+
15
+ export function ThemeProvider({ children, mode = 'light' }: Props) {
16
+ const theme = useMemo(() => {
17
+ return mode === 'dark' ? darkTheme : lightTheme;
18
+ }, [mode]);
19
+
20
+ return (
21
+ <ThemeContext.Provider value={{ theme, mode }}>
22
+ {children}
23
+ </ThemeContext.Provider>
24
+ );
25
+ }
@@ -0,0 +1,71 @@
1
+ // theme/themes.ts
2
+
3
+ import { palette } from './color';
4
+ import { spacing, radius } from './style';
5
+
6
+ export type ThemeMode = 'light' | 'dark';
7
+
8
+ export interface ThemeColors {
9
+ background: string;
10
+ surface: string;
11
+ text: string;
12
+
13
+ white: string;
14
+ primary: string;
15
+ secondary: string;
16
+ warning: string;
17
+ danger: string;
18
+
19
+ border: string;
20
+ disabled: string;
21
+ }
22
+
23
+ export type ThemeSpacing = typeof spacing;
24
+ export type ThemeRadius = typeof radius;
25
+
26
+ export interface AppTheme {
27
+ mode: ThemeMode;
28
+ colors: ThemeColors;
29
+ spacing: ThemeSpacing;
30
+ radius: ThemeRadius;
31
+ }
32
+
33
+ export const lightTheme: AppTheme = {
34
+ mode: 'light',
35
+ colors: {
36
+ background: '#FFFFFF',
37
+ surface: palette.gray100,
38
+ text: palette.gray900,
39
+
40
+ white: '#FFFFFF',
41
+ primary: palette.blue500,
42
+ secondary: '#8E8E93',
43
+ warning: palette.yellow500,
44
+ danger: palette.red500,
45
+
46
+ border: '#E5E5EA',
47
+ disabled: '#C7C7CC',
48
+ },
49
+ spacing,
50
+ radius,
51
+ };
52
+
53
+ export const darkTheme: AppTheme = {
54
+ mode: 'dark',
55
+ colors: {
56
+ background: '#000000',
57
+ surface: '#1C1C1E',
58
+ text: '#FFFFFF',
59
+
60
+ white: '#FFFFFF',
61
+ primary: palette.blue500,
62
+ secondary: '#AEAEB2',
63
+ warning: palette.yellow500,
64
+ danger: palette.red500,
65
+
66
+ border: '#38383A',
67
+ disabled: '#48484A',
68
+ },
69
+ spacing,
70
+ radius,
71
+ };