@momo-kits/native-kits 0.158.1-beta.1 → 0.158.1-beta.2-debug

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 (260) hide show
  1. package/build.gradle.kts +11 -0
  2. package/compose/build.gradle.kts +180 -0
  3. package/compose/build.gradle.kts.backup +180 -0
  4. package/compose/compose.podspec +54 -0
  5. package/compose/src/androidMain/kotlin/vn/momo/kits/platform/Platform.android.kt +117 -0
  6. package/compose/src/commonMain/composeResources/font/momosignature.otf +0 -0
  7. package/compose/src/commonMain/composeResources/font/momotrustdisplay.otf +0 -0
  8. package/compose/src/commonMain/composeResources/font/sfprotext_black.otf +0 -0
  9. package/compose/src/commonMain/composeResources/font/sfprotext_black.ttf +0 -0
  10. package/compose/src/commonMain/composeResources/font/sfprotext_bold.ttf +0 -0
  11. package/compose/src/commonMain/composeResources/font/sfprotext_heavy.ttf +0 -0
  12. package/compose/src/commonMain/composeResources/font/sfprotext_light.ttf +0 -0
  13. package/compose/src/commonMain/composeResources/font/sfprotext_medium.ttf +0 -0
  14. package/compose/src/commonMain/composeResources/font/sfprotext_regular.ttf +0 -0
  15. package/compose/src/commonMain/composeResources/font/sfprotext_semibold.ttf +0 -0
  16. package/compose/src/commonMain/composeResources/font/sfprotext_thin.otf +0 -0
  17. package/compose/src/commonMain/composeResources/font/sfprotext_thin.ttf +0 -0
  18. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.otf +0 -0
  19. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.ttf +0 -0
  20. package/compose/src/commonMain/kotlin/vn/momo/kits/application/AnimationSearchInput.kt +57 -0
  21. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Context.kt +107 -0
  22. package/compose/src/commonMain/kotlin/vn/momo/kits/application/FloatingButton.kt +201 -0
  23. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Header.kt +222 -0
  24. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderAnimated.kt +48 -0
  25. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderBackground.kt +86 -0
  26. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderDefault.kt +76 -0
  27. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderExtended.kt +76 -0
  28. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderRight.kt +305 -0
  29. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderTitle.kt +33 -0
  30. package/compose/src/commonMain/kotlin/vn/momo/kits/application/LiteScreen.kt +720 -0
  31. package/compose/src/commonMain/kotlin/vn/momo/kits/application/NavigationContainer.kt +121 -0
  32. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Screen.kt +405 -0
  33. package/compose/src/commonMain/kotlin/vn/momo/kits/application/useHeaderSearchAnimation.kt +69 -0
  34. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Avatar.kt +157 -0
  35. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Badge.kt +85 -0
  36. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeDot.kt +32 -0
  37. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeRibbon.kt +340 -0
  38. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BaselineView.kt +198 -0
  39. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Button.kt +357 -0
  40. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Carousel.kt +123 -0
  41. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CheckBox.kt +94 -0
  42. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Chip.kt +136 -0
  43. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Collapse.kt +224 -0
  44. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CupertinoOverscroll.kt +543 -0
  45. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Divider.kt +23 -0
  46. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Icon.kt +76 -0
  47. package/compose/src/commonMain/kotlin/vn/momo/kits/components/IconButton.kt +148 -0
  48. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Image.kt +188 -0
  49. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Information.kt +116 -0
  50. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Input.kt +448 -0
  51. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +172 -0
  52. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputMoney.kt +255 -0
  53. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputOTP.kt +231 -0
  54. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +233 -0
  55. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +254 -0
  56. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +241 -0
  57. package/compose/src/commonMain/kotlin/vn/momo/kits/components/LazyColumnWithBouncing.kt +364 -0
  58. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Loader.kt +108 -0
  59. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationDot.kt +56 -0
  60. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationNumber.kt +41 -0
  61. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationScroll.kt +92 -0
  62. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationWhiteDot.kt +40 -0
  63. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupNotify.kt +352 -0
  64. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupPromotion.kt +103 -0
  65. package/compose/src/commonMain/kotlin/vn/momo/kits/components/ProgressInfo.kt +338 -0
  66. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Radio.kt +70 -0
  67. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Rating.kt +87 -0
  68. package/compose/src/commonMain/kotlin/vn/momo/kits/components/ScaleSizeScope.kt +17 -0
  69. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +96 -0
  70. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Slider.kt +348 -0
  71. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Stepper.kt +256 -0
  72. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Steps.kt +494 -0
  73. package/compose/src/commonMain/kotlin/vn/momo/kits/components/SuggestAction.kt +131 -0
  74. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Swipe.kt +215 -0
  75. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +96 -0
  76. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TabView.kt +531 -0
  77. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +92 -0
  78. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +130 -0
  79. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +214 -0
  80. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tooltip.kt +590 -0
  81. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +177 -0
  82. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Uploader.kt +192 -0
  83. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +205 -0
  84. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerTypes.kt +29 -0
  85. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerUtils.kt +239 -0
  86. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/WheelPicker.kt +191 -0
  87. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Colors.kt +306 -0
  88. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Radius.kt +12 -0
  89. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Spacing.kt +16 -0
  90. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Theme.kt +188 -0
  91. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +285 -0
  92. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Card.kt +2 -0
  93. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Item.kt +35 -0
  94. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Section.kt +2 -0
  95. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/AutomationId.kt +50 -0
  96. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Clickable.kt +68 -0
  97. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Conditional.kt +11 -0
  98. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/DeprecatedModifier.kt +14 -0
  99. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +50 -0
  100. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Size.kt +51 -0
  101. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/BottomSheet.kt +253 -0
  102. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +133 -0
  103. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +99 -0
  104. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +164 -0
  105. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +333 -0
  106. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +552 -0
  107. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTab.kt +162 -0
  108. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTabBar.kt +243 -0
  109. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/CurvedContainer.kt +86 -0
  110. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/FloatingButton.kt +187 -0
  111. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/Header.kt +279 -0
  112. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderBackground.kt +80 -0
  113. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderRight.kt +306 -0
  114. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderTitle.kt +32 -0
  115. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderUser.kt +370 -0
  116. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/SnackBar.kt +132 -0
  117. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/tracking/ScreenTracker.kt +167 -0
  118. package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +46 -0
  119. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Icons.kt +1329 -0
  120. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Resources.kt +62 -0
  121. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Tracking.kt +15 -0
  122. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Utils.kt +88 -0
  123. package/compose/src/iosMain/kotlin/vn/momo/kits/platform/Platform.ios.kt +161 -0
  124. package/example/ios/Example.xcodeproj/xcuserdata/sonnguyen.xcuserdatad/xcschemes/Example.xcscheme +32 -0
  125. package/example/ios/Example.xcodeproj/xcuserdata/sonnguyen.xcuserdatad/xcschemes/xcschememanagement.plist +14 -0
  126. package/example/ios/Example.xcworkspace/xcuserdata/sonnguyen.xcuserdatad/UserInterfaceState.xcuserstate +0 -0
  127. package/example/ios/Example.xcworkspace/xcuserdata/sonnguyen.xcuserdatad/WorkspaceSettings.xcsettings +16 -0
  128. package/example/ios/Example.xcworkspace/xcuserdata/sonnguyen.xcuserdatad/xcdebugger/Breakpoints_v2.xcbkptlist +6 -0
  129. package/example/ios/Example.xcworkspace/xcuserdata/sonnguyen.xcuserdatad/xcschemes/xcschememanagement.plist +5 -0
  130. package/example/ios/Pods/Pods.xcodeproj/xcuserdata/sonnguyen.xcuserdatad/xcschemes/MoMoUIKits.xcscheme +58 -0
  131. package/example/ios/Pods/Pods.xcodeproj/xcuserdata/sonnguyen.xcuserdatad/xcschemes/Pods-Example.xcscheme +58 -0
  132. package/example/ios/Pods/Pods.xcodeproj/xcuserdata/sonnguyen.xcuserdatad/xcschemes/SDWebImage.xcscheme +58 -0
  133. package/example/ios/Pods/Pods.xcodeproj/xcuserdata/sonnguyen.xcuserdatad/xcschemes/SDWebImageSwiftUI.xcscheme +58 -0
  134. package/example/ios/Pods/Pods.xcodeproj/xcuserdata/sonnguyen.xcuserdatad/xcschemes/SkeletonUI.xcscheme +58 -0
  135. package/example/ios/Pods/Pods.xcodeproj/xcuserdata/sonnguyen.xcuserdatad/xcschemes/lottie-ios-LottiePrivacyInfo.xcscheme +58 -0
  136. package/example/ios/Pods/Pods.xcodeproj/xcuserdata/sonnguyen.xcuserdatad/xcschemes/lottie-ios.xcscheme +58 -0
  137. package/example/ios/Pods/Pods.xcodeproj/xcuserdata/sonnguyen.xcuserdatad/xcschemes/xcschememanagement.plist +60 -0
  138. package/gradle/libs.versions.toml +57 -0
  139. package/gradle/wrapper/gradle-wrapper.jar +0 -0
  140. package/gradle/wrapper/gradle-wrapper.properties +8 -0
  141. package/gradle.properties +26 -0
  142. package/gradlew +252 -0
  143. package/gradlew.bat +94 -0
  144. package/local.properties +8 -0
  145. package/package.json +1 -1
  146. package/settings.gradle.kts +52 -0
  147. package/.claude/settings.local.json +0 -11
  148. package/.claude/skills/design-system/SKILL.md +0 -88
  149. package/.claude/skills/design-system/references/components/avatar.md +0 -134
  150. package/.claude/skills/design-system/references/components/badge.md +0 -127
  151. package/.claude/skills/design-system/references/components/bottom-tab.md +0 -177
  152. package/.claude/skills/design-system/references/components/bottomsheet.md +0 -170
  153. package/.claude/skills/design-system/references/components/button.md +0 -206
  154. package/.claude/skills/design-system/references/components/carousel.md +0 -117
  155. package/.claude/skills/design-system/references/components/checkbox.md +0 -98
  156. package/.claude/skills/design-system/references/components/chip.md +0 -146
  157. package/.claude/skills/design-system/references/components/collapse.md +0 -120
  158. package/.claude/skills/design-system/references/components/date-picker.md +0 -119
  159. package/.claude/skills/design-system/references/components/divider.md +0 -84
  160. package/.claude/skills/design-system/references/components/icon.md +0 -130
  161. package/.claude/skills/design-system/references/components/image.md +0 -81
  162. package/.claude/skills/design-system/references/components/information.md +0 -107
  163. package/.claude/skills/design-system/references/components/input-dropdown.md +0 -138
  164. package/.claude/skills/design-system/references/components/input-money.md +0 -157
  165. package/.claude/skills/design-system/references/components/input-otp.md +0 -132
  166. package/.claude/skills/design-system/references/components/input-phone-number.md +0 -140
  167. package/.claude/skills/design-system/references/components/input-search.md +0 -124
  168. package/.claude/skills/design-system/references/components/input-text-area.md +0 -133
  169. package/.claude/skills/design-system/references/components/input.md +0 -152
  170. package/.claude/skills/design-system/references/components/loader.md +0 -87
  171. package/.claude/skills/design-system/references/components/pagination.md +0 -105
  172. package/.claude/skills/design-system/references/components/popup-notify.md +0 -128
  173. package/.claude/skills/design-system/references/components/progress-info.md +0 -114
  174. package/.claude/skills/design-system/references/components/radio.md +0 -86
  175. package/.claude/skills/design-system/references/components/rating.md +0 -126
  176. package/.claude/skills/design-system/references/components/skeleton.md +0 -120
  177. package/.claude/skills/design-system/references/components/slider.md +0 -141
  178. package/.claude/skills/design-system/references/components/snackbar.md +0 -97
  179. package/.claude/skills/design-system/references/components/stepper.md +0 -100
  180. package/.claude/skills/design-system/references/components/steps.md +0 -91
  181. package/.claude/skills/design-system/references/components/suggest-action.md +0 -95
  182. package/.claude/skills/design-system/references/components/swipe.md +0 -121
  183. package/.claude/skills/design-system/references/components/switch.md +0 -98
  184. package/.claude/skills/design-system/references/components/tab-view.md +0 -120
  185. package/.claude/skills/design-system/references/components/tag.md +0 -118
  186. package/.claude/skills/design-system/references/components/text.md +0 -151
  187. package/.claude/skills/design-system/references/components/toast.md +0 -99
  188. package/.claude/skills/design-system/references/components/tooltip.md +0 -138
  189. package/.claude/skills/design-system/references/components/top-nav-miniapp.md +0 -94
  190. package/.claude/skills/design-system/references/components/top-nav.md +0 -226
  191. package/.claude/skills/design-system/references/components/uploader.md +0 -115
  192. package/.claude/skills/design-system/references/navigation/bottom-tab.md +0 -131
  193. package/.claude/skills/design-system/references/navigation/bottomsheet.md +0 -161
  194. package/.claude/skills/design-system/references/navigation/modal.md +0 -133
  195. package/.claude/skills/design-system/references/navigation/navigation-options.md +0 -225
  196. package/.claude/skills/design-system/references/navigation/navigator.md +0 -111
  197. package/.claude/skills/design-system/references/navigation/setup.md +0 -134
  198. package/.claude/skills/design-system/references/navigation/stack.md +0 -128
  199. package/.claude/skills/design-system/references/spec-convention.md +0 -80
  200. package/.claude/skills/design-system/references/tokens/colors.md +0 -131
  201. package/.claude/skills/design-system/references/tokens/spacing-radius.md +0 -144
  202. package/.claude/skills/design-system/references/tokens/theme.md +0 -125
  203. package/.claude/skills/design-system/references/tokens/typography.md +0 -135
  204. package/.claude/skills/design-system-kits/SKILL.md +0 -102
  205. package/.claude/skills/design-system-kits/references/code-convention.md +0 -118
  206. package/.claude/skills/design-system-kits/references/components/avatar.md +0 -45
  207. package/.claude/skills/design-system-kits/references/components/badge.md +0 -27
  208. package/.claude/skills/design-system-kits/references/components/button.md +0 -65
  209. package/.claude/skills/design-system-kits/references/components/carousel.md +0 -51
  210. package/.claude/skills/design-system-kits/references/components/checkbox.md +0 -39
  211. package/.claude/skills/design-system-kits/references/components/chip.md +0 -54
  212. package/.claude/skills/design-system-kits/references/components/collapse.md +0 -63
  213. package/.claude/skills/design-system-kits/references/components/date-picker.md +0 -36
  214. package/.claude/skills/design-system-kits/references/components/divider.md +0 -21
  215. package/.claude/skills/design-system-kits/references/components/icon.md +0 -382
  216. package/.claude/skills/design-system-kits/references/components/image.md +0 -62
  217. package/.claude/skills/design-system-kits/references/components/information.md +0 -61
  218. package/.claude/skills/design-system-kits/references/components/input-dropdown.md +0 -92
  219. package/.claude/skills/design-system-kits/references/components/input-money.md +0 -128
  220. package/.claude/skills/design-system-kits/references/components/input-otp.md +0 -85
  221. package/.claude/skills/design-system-kits/references/components/input-phone-number.md +0 -96
  222. package/.claude/skills/design-system-kits/references/components/input-search.md +0 -127
  223. package/.claude/skills/design-system-kits/references/components/input-text-area.md +0 -100
  224. package/.claude/skills/design-system-kits/references/components/input.md +0 -126
  225. package/.claude/skills/design-system-kits/references/components/loader.md +0 -41
  226. package/.claude/skills/design-system-kits/references/components/pagination.md +0 -47
  227. package/.claude/skills/design-system-kits/references/components/popup-notify.md +0 -69
  228. package/.claude/skills/design-system-kits/references/components/popup-promotion.md +0 -35
  229. package/.claude/skills/design-system-kits/references/components/progress-info.md +0 -55
  230. package/.claude/skills/design-system-kits/references/components/radio.md +0 -42
  231. package/.claude/skills/design-system-kits/references/components/rating.md +0 -36
  232. package/.claude/skills/design-system-kits/references/components/skeleton.md +0 -25
  233. package/.claude/skills/design-system-kits/references/components/slider.md +0 -53
  234. package/.claude/skills/design-system-kits/references/components/snackbar.md +0 -52
  235. package/.claude/skills/design-system-kits/references/components/stepper.md +0 -46
  236. package/.claude/skills/design-system-kits/references/components/steps.md +0 -57
  237. package/.claude/skills/design-system-kits/references/components/suggest-action.md +0 -44
  238. package/.claude/skills/design-system-kits/references/components/swipe.md +0 -44
  239. package/.claude/skills/design-system-kits/references/components/switch.md +0 -43
  240. package/.claude/skills/design-system-kits/references/components/tab-view.md +0 -56
  241. package/.claude/skills/design-system-kits/references/components/tag.md +0 -50
  242. package/.claude/skills/design-system-kits/references/components/text.md +0 -56
  243. package/.claude/skills/design-system-kits/references/components/toast.md +0 -51
  244. package/.claude/skills/design-system-kits/references/components/tooltip.md +0 -95
  245. package/.claude/skills/design-system-kits/references/components/uploader.md +0 -48
  246. package/.claude/skills/design-system-kits/references/design-spec-structure.md +0 -356
  247. package/.claude/skills/design-system-kits/references/design-spec-to-code.md +0 -596
  248. package/.claude/skills/design-system-kits/references/navigation/bottom-tab.md +0 -155
  249. package/.claude/skills/design-system-kits/references/navigation/bottomsheet.md +0 -94
  250. package/.claude/skills/design-system-kits/references/navigation/modal.md +0 -125
  251. package/.claude/skills/design-system-kits/references/navigation/navigation-options.md +0 -430
  252. package/.claude/skills/design-system-kits/references/navigation/navigator.md +0 -177
  253. package/.claude/skills/design-system-kits/references/navigation/setup.md +0 -94
  254. package/.claude/skills/design-system-kits/references/navigation/stack.md +0 -152
  255. package/.claude/skills/design-system-kits/references/screen-layout-rule.md +0 -125
  256. package/.claude/skills/design-system-kits/references/tokens/colors.md +0 -183
  257. package/.claude/skills/design-system-kits/references/tokens/spacing-radius.md +0 -45
  258. package/.claude/skills/design-system-kits/references/tokens/theme.md +0 -97
  259. package/.claude/skills/design-system-kits/references/tokens/typography.md +0 -105
  260. package/.claude/skills/vibe-design/SKILL.md +0 -306
@@ -0,0 +1,94 @@
1
+ package vn.momo.kits.components
2
+
3
+ import androidx.compose.foundation.background
4
+ import androidx.compose.foundation.border
5
+ import androidx.compose.foundation.layout.Box
6
+ import androidx.compose.foundation.layout.Row
7
+ import androidx.compose.foundation.layout.Spacer
8
+ import androidx.compose.foundation.layout.size
9
+ import androidx.compose.foundation.shape.RoundedCornerShape
10
+ import androidx.compose.runtime.Composable
11
+ import androidx.compose.runtime.remember
12
+ import androidx.compose.ui.Alignment
13
+ import androidx.compose.ui.Modifier
14
+ import androidx.compose.ui.graphics.Color
15
+ import androidx.compose.ui.unit.dp
16
+ import vn.momo.kits.application.IsShowBaseLineDebug
17
+ import vn.momo.kits.const.AppTheme
18
+ import vn.momo.kits.const.Colors
19
+ import vn.momo.kits.const.Radius
20
+ import vn.momo.kits.const.Spacing
21
+ import vn.momo.kits.const.Typography
22
+ import vn.momo.kits.modifier.activeOpacityClickable
23
+ import vn.momo.kits.modifier.conditional
24
+
25
+ // Pre-computed shape for performance
26
+ private val checkboxShape = RoundedCornerShape(Radius.XS)
27
+
28
+ @Composable
29
+ fun CheckBox(
30
+ disabled: Boolean = false,
31
+ checked: Boolean = false,
32
+ onCheckedChange: (Boolean) -> Unit,
33
+ indeterminate: Boolean = false,
34
+ title: String = "",
35
+ ) {
36
+ // Cache theme access
37
+ val theme = AppTheme.current
38
+
39
+ // Memoize color calculations to avoid repeated conditional logic
40
+ val colors = remember(checked, disabled, theme) {
41
+ when {
42
+ disabled && checked -> Pair(theme.colors.background.tonal, theme.colors.background.tonal)
43
+ disabled -> Pair(theme.colors.border.disable, Color.Transparent)
44
+ checked -> Pair(theme.colors.primary, theme.colors.primary)
45
+ else -> Pair(theme.colors.text.default, Color.Transparent)
46
+ }
47
+ }
48
+
49
+ val (borderColor, backgroundColor) = colors
50
+
51
+ // Memoize icon source to avoid repeated conditional check
52
+ val iconSource = remember(indeterminate) {
53
+ if (indeterminate) "navigation_minus" else "ic_checked"
54
+ }
55
+
56
+ // Memoize click handler to avoid lambda recreation
57
+ val onClickHandler = remember(onCheckedChange, checked) {
58
+ { onCheckedChange(!checked) }
59
+ }
60
+
61
+ Row(verticalAlignment = Alignment.CenterVertically) {
62
+ Box(
63
+ modifier = Modifier
64
+ .size(20.dp)
65
+ .background(backgroundColor, checkboxShape)
66
+ .border(Spacing.XXS, borderColor, checkboxShape)
67
+ .conditional(IsShowBaseLineDebug) {
68
+ border(1.dp, Colors.blue_03)
69
+ }
70
+ .activeOpacityClickable(
71
+ activeOpacity = 0.8f,
72
+ onClick = onClickHandler,
73
+ enabled = !disabled,
74
+ ),
75
+ ) {
76
+ if (checked) {
77
+ Icon(
78
+ source = iconSource,
79
+ size = 20.dp,
80
+ color = Colors.black_01
81
+ )
82
+ }
83
+ }
84
+
85
+ if (title.isNotEmpty()) {
86
+ Spacer(Modifier.size(Spacing.S))
87
+ Text(
88
+ style = Typography.descriptionDefaultRegular,
89
+ text = title,
90
+ )
91
+ }
92
+ }
93
+
94
+ }
@@ -0,0 +1,136 @@
1
+ package vn.momo.kits.components
2
+
3
+ import androidx.compose.foundation.background
4
+ import androidx.compose.foundation.border
5
+ import androidx.compose.foundation.layout.Arrangement
6
+ import androidx.compose.foundation.layout.Row
7
+ import androidx.compose.foundation.layout.height
8
+ import androidx.compose.foundation.layout.padding
9
+ import androidx.compose.foundation.layout.wrapContentWidth
10
+ import androidx.compose.foundation.shape.RoundedCornerShape
11
+ import androidx.compose.runtime.Composable
12
+ import androidx.compose.runtime.Immutable
13
+ import androidx.compose.ui.Alignment
14
+ import androidx.compose.ui.Modifier
15
+ import androidx.compose.ui.draw.clip
16
+ import androidx.compose.ui.graphics.Color
17
+ import androidx.compose.ui.text.style.TextAlign
18
+ import androidx.compose.ui.text.style.TextOverflow
19
+ import androidx.compose.ui.unit.dp
20
+ import vn.momo.kits.const.AppTheme
21
+ import vn.momo.kits.const.Colors
22
+ import vn.momo.kits.const.Radius
23
+ import vn.momo.kits.const.Typography
24
+ import vn.momo.kits.application.IsShowBaseLineDebug
25
+ import vn.momo.kits.const.scaleSize
26
+ import vn.momo.kits.modifier.activeOpacityClickable
27
+ import vn.momo.kits.modifier.conditional
28
+ import vn.momo.kits.modifier.setAutomationId
29
+
30
+ @Composable
31
+ fun Chip(
32
+ modifier: Modifier = Modifier,
33
+ label: String? = "Label",
34
+ iconLeft: String? = null,
35
+ iconRight: String? = null,
36
+ selected: Boolean = false,
37
+ onClick: () -> Unit = {},
38
+ size: ChipSize = ChipSize.LARGE,
39
+ iconLeftTint: Color? = null,
40
+ iconRightTint: Color? = null,
41
+ backgroundColor: Color? = null,
42
+ accessibilityLabel: String? = null,
43
+ ) {
44
+ val theme = AppTheme.current
45
+ val bg = when {
46
+ selected -> theme.colors.background.selected
47
+ backgroundColor != null -> backgroundColor
48
+ else -> Colors.black_03
49
+ }
50
+
51
+ val textColor = if (selected) theme.colors.primary else theme.colors.text.default
52
+ val leftTint = if (selected) theme.colors.primary else iconLeftTint ?: theme.colors.text.default
53
+ val rightTint = if (selected) theme.colors.primary else iconRightTint ?: theme.colors.text.default
54
+
55
+ val dims = when (size) {
56
+ ChipSize.SMALL -> ChipDefaults.Small
57
+ ChipSize.LARGE -> ChipDefaults.Large
58
+ }
59
+
60
+ val (height, horizontal, iconSize, iconSpacing) =
61
+ listOf(scaleSize(dims.height), scaleSize(dims.horizontal), scaleSize(dims.iconSize), scaleSize(dims.iconSpacing))
62
+
63
+ val radius = scaleSize(Radius.L)
64
+
65
+ Row(
66
+ modifier
67
+ .wrapContentWidth()
68
+ .height(height.dp)
69
+ .clip(RoundedCornerShape(radius))
70
+ .background(bg)
71
+ .conditional(selected) {
72
+ Modifier.border(width = 2.dp, color = theme.colors.secondary, shape = RoundedCornerShape(radius))
73
+ }
74
+ .conditional(IsShowBaseLineDebug) {
75
+ border(1.dp, Colors.blue_03)
76
+ }
77
+ .activeOpacityClickable {
78
+ onClick()
79
+ }
80
+ .padding(horizontal = horizontal.dp)
81
+ .conditional(accessibilityLabel != null) {
82
+ setAutomationId(accessibilityLabel.toString())
83
+ },
84
+ verticalAlignment = Alignment.CenterVertically,
85
+ horizontalArrangement = Arrangement.spacedBy(iconSpacing.dp)
86
+ ) {
87
+ if (iconLeft != null) {
88
+ Icon(source = iconLeft, size = dims.iconSize.dp, color = leftTint)
89
+ }
90
+
91
+ if (!label.isNullOrEmpty()) {
92
+ Text(
93
+ text = label,
94
+ textAlign = TextAlign.Center,
95
+ color = textColor,
96
+ style = when (size) {
97
+ ChipSize.SMALL -> Typography.labelSMedium
98
+ ChipSize.LARGE -> Typography.labelDefaultMedium
99
+ },
100
+ maxLines = 1,
101
+ overflow = TextOverflow.Ellipsis,
102
+ modifier = Modifier.weight(1f, fill = false),
103
+ )
104
+ }
105
+
106
+ if (iconRight != null) {
107
+ Icon(source = iconRight, size = iconSize.dp, color = rightTint)
108
+ }
109
+ }
110
+ }
111
+
112
+ enum class ChipSize { SMALL, LARGE }
113
+
114
+ object ChipDefaults {
115
+ @Immutable
116
+ data class Dimensions(
117
+ val height: Float,
118
+ val horizontal: Float,
119
+ val iconSize: Float,
120
+ val iconSpacing: Float,
121
+ )
122
+
123
+ val Large = Dimensions(
124
+ height = 32f,
125
+ horizontal = 12f,
126
+ iconSize = 20f,
127
+ iconSpacing = 4f,
128
+ )
129
+
130
+ val Small = Dimensions(
131
+ height = 24f,
132
+ horizontal = 10f,
133
+ iconSize = 16f,
134
+ iconSpacing = 4f,
135
+ )
136
+ }
@@ -0,0 +1,224 @@
1
+ package vn.momo.kits.components
2
+
3
+ import androidx.compose.animation.AnimatedVisibility
4
+ import androidx.compose.animation.core.animateFloatAsState
5
+ import androidx.compose.animation.core.tween
6
+ import androidx.compose.animation.expandVertically
7
+ import androidx.compose.animation.shrinkVertically
8
+ import androidx.compose.foundation.background
9
+ import androidx.compose.foundation.border
10
+ import androidx.compose.foundation.layout.Box
11
+ import androidx.compose.foundation.layout.Column
12
+ import androidx.compose.foundation.layout.Row
13
+ import androidx.compose.foundation.layout.Spacer
14
+ import androidx.compose.foundation.layout.fillMaxWidth
15
+ import androidx.compose.foundation.layout.padding
16
+ import androidx.compose.foundation.layout.size
17
+ import androidx.compose.foundation.layout.width
18
+ import androidx.compose.foundation.shape.RoundedCornerShape
19
+ import androidx.compose.runtime.Composable
20
+ import androidx.compose.runtime.getValue
21
+ import androidx.compose.runtime.mutableStateOf
22
+ import androidx.compose.runtime.remember
23
+ import androidx.compose.runtime.setValue
24
+ import androidx.compose.ui.Alignment
25
+ import androidx.compose.ui.Modifier
26
+ import androidx.compose.ui.draw.clip
27
+ import androidx.compose.ui.draw.rotate
28
+ import androidx.compose.ui.graphics.Color
29
+ import androidx.compose.ui.text.TextStyle
30
+ import androidx.compose.ui.unit.dp
31
+ import vn.momo.kits.application.IsShowBaseLineDebug
32
+ import vn.momo.kits.const.AppTheme
33
+ import vn.momo.kits.const.Colors
34
+ import vn.momo.kits.const.Radius
35
+ import vn.momo.kits.const.Spacing
36
+ import vn.momo.kits.const.Typography
37
+ import vn.momo.kits.modifier.activeOpacityClickable
38
+ import vn.momo.kits.modifier.conditional
39
+ import vn.momo.kits.modifier.setAutomationId
40
+
41
+ enum class CollapseTitleSize {
42
+ Small, Medium, Large
43
+ }
44
+
45
+ @Composable
46
+ fun Collapse(
47
+ title: String,
48
+ modifier: Modifier = Modifier,
49
+ description: String? = null,
50
+ image: String? = null,
51
+ imageSize: Int = 24,
52
+ subTitle: String? = null,
53
+ tagLabel: String? = null,
54
+ tagColor: TagColor = TagColor.Default,
55
+ showBorder: Boolean = false,
56
+ expandDefault: Boolean = false,
57
+ titleSize: CollapseTitleSize = CollapseTitleSize.Medium,
58
+ useBackgroundCollapseButton: Boolean = false,
59
+ backgroundColor: Color? = null,
60
+ titleColor: Color? = null,
61
+ onPress: ((isExpanded: Boolean) -> Unit)? = null,
62
+ accessibilityId: String? = null,
63
+ content: (@Composable () -> Unit)? = null,
64
+ ) {
65
+ val theme = AppTheme.current
66
+
67
+ var expanded by remember { mutableStateOf(expandDefault) }
68
+
69
+ val chevronRotation by animateFloatAsState(
70
+ targetValue = if (expanded) 180f else 0f,
71
+ animationSpec = tween(durationMillis = 300),
72
+ label = "chevronRotation"
73
+ )
74
+
75
+ val resolvedBackgroundColor = remember(backgroundColor, theme) {
76
+ backgroundColor ?: theme.colors.background.surface
77
+ }
78
+
79
+ val resolvedTitleStyle: TextStyle = remember(titleSize) {
80
+ when (titleSize) {
81
+ CollapseTitleSize.Small -> Typography.headerSSemibold
82
+ CollapseTitleSize.Medium -> Typography.headerDefaultBold
83
+ CollapseTitleSize.Large -> Typography.headerMBold
84
+ }
85
+ }
86
+
87
+ val borderShape = remember { RoundedCornerShape(Radius.S) }
88
+
89
+ val automationId = remember(accessibilityId, title) {
90
+ accessibilityId ?: "Collapse/$title"
91
+ }
92
+
93
+ Column(
94
+ modifier = modifier
95
+ .fillMaxWidth()
96
+ .clip(borderShape)
97
+ .background(resolvedBackgroundColor, shape = borderShape)
98
+ .conditional(showBorder) {
99
+ border(
100
+ width = 1.dp,
101
+ color = theme.colors.border.default,
102
+ shape = borderShape
103
+ )
104
+ }
105
+ .conditional(IsShowBaseLineDebug) {
106
+ border(1.dp, Colors.blue_03)
107
+ }
108
+ .setAutomationId(automationId)
109
+ ) {
110
+ Row(
111
+ modifier = Modifier
112
+ .fillMaxWidth()
113
+ .activeOpacityClickable {
114
+ onPress?.invoke(expanded)
115
+ expanded = !expanded
116
+ }
117
+ .padding(horizontal = Spacing.M, vertical = Spacing.S)
118
+ .setAutomationId("$automationId|touch"),
119
+ verticalAlignment = Alignment.Top
120
+ ) {
121
+ if (image != null) {
122
+ Image(
123
+ source = image,
124
+ modifier = Modifier
125
+ .size(imageSize.dp)
126
+ .clip(RoundedCornerShape(Radius.XS))
127
+ .setAutomationId("$automationId|img")
128
+ )
129
+ Spacer(modifier = Modifier.width(Spacing.S))
130
+ }
131
+
132
+ Column(modifier = Modifier.weight(1f)) {
133
+ Text(
134
+ text = title,
135
+ style = resolvedTitleStyle,
136
+ color = titleColor ?: theme.colors.text.default,
137
+ accessibilityId = "$automationId|text"
138
+ )
139
+ if (description != null) {
140
+ Text(
141
+ text = description,
142
+ style = Typography.bodyDefaultRegular,
143
+ color = theme.colors.text.secondary,
144
+ maxLines = 2,
145
+ accessibilityId = "$automationId|description-text"
146
+ )
147
+ }
148
+ }
149
+
150
+ val hasInfo = subTitle != null || tagLabel != null
151
+ if (hasInfo) {
152
+ Spacer(modifier = Modifier.width(Spacing.S))
153
+ Box(contentAlignment = Alignment.CenterEnd) {
154
+ if (subTitle != null) {
155
+ Text(
156
+ text = subTitle,
157
+ style = Typography.bodyDefaultRegular,
158
+ color = theme.colors.text.secondary,
159
+ maxLines = 1,
160
+ accessibilityId = "$automationId|sub-title-text"
161
+ )
162
+ } else if (tagLabel != null) {
163
+ Tag(
164
+ label = tagLabel,
165
+ color = tagColor
166
+ )
167
+ }
168
+ }
169
+ }
170
+
171
+ Spacer(modifier = Modifier.width(Spacing.S))
172
+ if (useBackgroundCollapseButton) {
173
+ Box(
174
+ modifier = Modifier
175
+ .size(24.dp)
176
+ .background(
177
+ color = theme.colors.background.tonal,
178
+ shape = RoundedCornerShape(Radius.M)
179
+ ),
180
+ contentAlignment = Alignment.Center
181
+ ) {
182
+ Icon(
183
+ source = "arrow_chevron_down_small",
184
+ size = 16.dp,
185
+ color = theme.colors.primary,
186
+ modifier = Modifier
187
+ .rotate(chevronRotation)
188
+ .setAutomationId("$automationId|icon")
189
+ )
190
+ }
191
+ } else {
192
+ Icon(
193
+ source = "arrow_chevron_down_small",
194
+ size = 24.dp,
195
+ color = theme.colors.text.default,
196
+ modifier = Modifier
197
+ .rotate(chevronRotation)
198
+ .setAutomationId("$automationId|icon")
199
+ )
200
+ }
201
+ }
202
+
203
+ if (content != null) {
204
+ AnimatedVisibility(
205
+ visible = expanded,
206
+ enter = expandVertically(animationSpec = tween(durationMillis = 300)),
207
+ exit = shrinkVertically(animationSpec = tween(durationMillis = 300))
208
+ ) {
209
+ Column(
210
+ modifier = Modifier
211
+ .fillMaxWidth()
212
+ .conditional(showBorder) {
213
+ border(
214
+ width = 1.dp,
215
+ color = theme.colors.border.default
216
+ )
217
+ }
218
+ ) {
219
+ content()
220
+ }
221
+ }
222
+ }
223
+ }
224
+ }