@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,76 @@
1
+ package vn.momo.kits.application
2
+
3
+ import androidx.compose.foundation.background
4
+ import androidx.compose.foundation.layout.Box
5
+ import androidx.compose.foundation.layout.fillMaxWidth
6
+ import androidx.compose.foundation.layout.height
7
+ import androidx.compose.runtime.Composable
8
+ import androidx.compose.ui.Modifier
9
+ import androidx.compose.ui.draw.alpha
10
+ import androidx.compose.ui.geometry.Offset
11
+ import androidx.compose.ui.graphics.Brush
12
+ import androidx.compose.ui.graphics.Color
13
+ import androidx.compose.ui.layout.ContentScale
14
+ import androidx.compose.ui.platform.LocalDensity
15
+ import androidx.compose.ui.unit.Dp
16
+ import androidx.compose.ui.unit.dp
17
+ import vn.momo.kits.components.Image
18
+ import vn.momo.kits.components.Options
19
+ import vn.momo.kits.const.AppTheme
20
+ import vn.momo.kits.utils.bottomBorder
21
+
22
+ @Deprecated("Use vn.momo.kits.navigation.component.Header instead", ReplaceWith("vn.momo.kits.navigation.component.Header"))
23
+ @Composable
24
+ fun HeaderDefault(
25
+ opacityAni: Float,
26
+ statusBarHeight: Dp,
27
+ backgroundColor: Color?,
28
+ headerTransparent: Boolean = false
29
+ ) {
30
+ val height = statusBarHeight + HEADER_HEIGHT.dp
31
+ Box(
32
+ modifier = Modifier.fillMaxWidth().height(height)
33
+ .background(if(headerTransparent && backgroundColor != null) backgroundColor else AppTheme.current.colors.background.surface)
34
+ .bottomBorder(
35
+ strokeWidth = 1.dp,
36
+ color = if(headerTransparent && backgroundColor != null) backgroundColor else AppTheme.current.colors.border.default
37
+ )
38
+ ) {
39
+ Box(
40
+ modifier = Modifier
41
+ .height(height)
42
+ .fillMaxWidth()
43
+ .alpha(opacityAni)
44
+ .background(
45
+ if (headerTransparent)
46
+ Brush.linearGradient(
47
+ colors = listOf(
48
+ Color.Transparent,
49
+ Color.Transparent,
50
+ ),
51
+ start = Offset(0f, 0f),
52
+ end = Offset(0f, with(LocalDensity.current) { 154.dp.toPx() })
53
+ )
54
+ else
55
+ Brush.linearGradient(
56
+ colors = listOf(
57
+ Color(0xFFFDCADE),
58
+ Color(0x00FDCADE)
59
+ ),
60
+ start = Offset(0f, 0f),
61
+ end = Offset(0f, with(LocalDensity.current) { 154.dp.toPx() })
62
+ )
63
+ )
64
+ )
65
+ if (AppTheme.current.assets.headerBackground != null) {
66
+ Image(
67
+ loading = false,
68
+ source = AppTheme.current.assets.headerBackground!!,
69
+ modifier = Modifier.fillMaxWidth().height(height),
70
+ options = Options(
71
+ contentScale = ContentScale.FillWidth
72
+ )
73
+ )
74
+ }
75
+ }
76
+ }
@@ -0,0 +1,76 @@
1
+ package vn.momo.kits.application
2
+
3
+ import androidx.compose.foundation.background
4
+ import androidx.compose.foundation.layout.Box
5
+ import androidx.compose.foundation.layout.fillMaxWidth
6
+ import androidx.compose.foundation.layout.height
7
+ import androidx.compose.runtime.Composable
8
+ import androidx.compose.ui.Modifier
9
+ import androidx.compose.ui.draw.alpha
10
+ import androidx.compose.ui.geometry.Offset
11
+ import androidx.compose.ui.graphics.Brush
12
+ import androidx.compose.ui.graphics.Color
13
+ import androidx.compose.ui.layout.ContentScale
14
+ import androidx.compose.ui.platform.LocalDensity
15
+ import androidx.compose.ui.unit.Dp
16
+ import androidx.compose.ui.unit.dp
17
+ import vn.momo.kits.components.Image
18
+ import vn.momo.kits.components.Options
19
+ import vn.momo.kits.const.AppTheme
20
+ import vn.momo.kits.utils.bottomBorder
21
+
22
+ @Deprecated("Use vn.momo.kits.navigation.component.Header instead", ReplaceWith("vn.momo.kits.navigation.component.Header"))
23
+ @Composable
24
+ fun HeaderExtended(
25
+ opacityAni: Float,
26
+ statusBarHeight: Dp,
27
+ backgroundColor: Color
28
+ ) {
29
+ Box(
30
+ modifier = Modifier
31
+ .fillMaxWidth()
32
+ .height(154.dp)
33
+ .alpha(opacityAni)
34
+ .background(
35
+ Brush.linearGradient(
36
+ colors = listOf(
37
+ Color(0xFFFDCADE),
38
+ Color(0x00FDCADE)
39
+ ),
40
+ start = Offset(0f, 0f),
41
+ end = Offset(0f, with(LocalDensity.current) { 154.dp.toPx() })
42
+ )
43
+ )
44
+ ) {
45
+ if (AppTheme.current.assets.headerBackground != null) {
46
+ Box(
47
+ modifier = Modifier
48
+ .fillMaxWidth()
49
+ .background(backgroundColor)
50
+ ) {
51
+ Image(
52
+ loading = false,
53
+ source = AppTheme.current.assets.headerBackground!!,
54
+ modifier = Modifier.fillMaxWidth().height(154.dp),
55
+ options = Options(
56
+ contentScale = ContentScale.FillWidth
57
+ )
58
+ )
59
+ }
60
+ }
61
+ }
62
+
63
+ Box(
64
+ modifier = Modifier
65
+ .fillMaxWidth()
66
+ .alpha(1f - opacityAni)
67
+ .height(statusBarHeight + HEADER_HEIGHT.dp)
68
+ .background(
69
+ AppTheme.current.colors.background.surface
70
+ )
71
+ .bottomBorder(
72
+ strokeWidth = 1.dp,
73
+ color = AppTheme.current.colors.border.default
74
+ )
75
+ )
76
+ }
@@ -0,0 +1,305 @@
1
+ package vn.momo.kits.application
2
+
3
+ import androidx.compose.foundation.background
4
+ import androidx.compose.foundation.border
5
+ import androidx.compose.foundation.clickable
6
+ import androidx.compose.foundation.layout.Arrangement
7
+ import androidx.compose.foundation.layout.Box
8
+ import androidx.compose.foundation.layout.Row
9
+ import androidx.compose.foundation.layout.height
10
+ import androidx.compose.foundation.layout.offset
11
+ import androidx.compose.foundation.layout.padding
12
+ import androidx.compose.foundation.layout.size
13
+ import androidx.compose.foundation.layout.width
14
+ import androidx.compose.foundation.shape.CircleShape
15
+ import androidx.compose.foundation.shape.RoundedCornerShape
16
+ import androidx.compose.runtime.Composable
17
+ import androidx.compose.runtime.Stable
18
+ import androidx.compose.runtime.getValue
19
+ import androidx.compose.runtime.mutableStateOf
20
+ import androidx.compose.runtime.remember
21
+ import androidx.compose.runtime.setValue
22
+ import androidx.compose.ui.Alignment
23
+ import androidx.compose.ui.Modifier
24
+ import androidx.compose.ui.draw.clip
25
+ import androidx.compose.ui.graphics.Color
26
+ import androidx.compose.ui.unit.dp
27
+ import kotlinx.serialization.json.Json
28
+ import kotlinx.serialization.json.jsonObject
29
+ import kotlinx.serialization.json.jsonPrimitive
30
+ import vn.momo.kits.components.BadgeDot
31
+ import vn.momo.kits.components.DotSize
32
+ import vn.momo.kits.components.Icon
33
+ import vn.momo.kits.const.AppTheme
34
+ import vn.momo.kits.const.Colors
35
+ import vn.momo.kits.const.Spacing
36
+
37
+ @Stable
38
+ data class HeaderRightData(
39
+ val useShortcut: Boolean = false,
40
+ val useMore: Boolean = false,
41
+ val useSystemTools: Boolean = true,
42
+ val tools: List<ToolGroup> = emptyList(),
43
+ val toolCallback: ((String) -> Unit)? = { _ -> }
44
+ )
45
+
46
+ data class Tool(
47
+ val key: String,
48
+ val icon: String,
49
+ val showBadge: Boolean = false,
50
+ val name: Map<String, String> = emptyMap(),
51
+ val showRightIcon: Boolean = true,
52
+ ) {
53
+ fun toMap(): Map<String, Any> {
54
+ return mapOf(
55
+ "key" to key,
56
+ "icon" to icon,
57
+ "showBadge" to showBadge,
58
+ "name" to name,
59
+ "showRightIcon" to showRightIcon
60
+ )
61
+ }
62
+ }
63
+
64
+ data class ToolGroup(
65
+ val title: Map<String, String> = emptyMap(),
66
+ val items: List<Tool>
67
+ ) {
68
+ fun toMap(): Map<String, Any> {
69
+ return mapOf(
70
+ "title" to title,
71
+ "items" to items.map { it.toMap() }
72
+ )
73
+ }
74
+ }
75
+
76
+ data class NavigationButtonConfig(
77
+ val icon: String,
78
+ val onPress: () -> Unit
79
+ )
80
+
81
+
82
+
83
+ @Deprecated("Use vn.momo.kits.navigation.component.HeaderRight instead", ReplaceWith("vn.momo.kits.navigation.component.HeaderRight"))
84
+ @Composable
85
+ fun HeaderRight(
86
+ headerRight: HeaderRightData? = null,
87
+ opacity: Float = 1f,
88
+ animatedHeader: AnimatedHeader? = null,
89
+ tintColor: Color? = null,
90
+ ) {
91
+ Row(
92
+ verticalAlignment = Alignment.CenterVertically,
93
+ ) {
94
+ ToolkitHeaderRight(headerRight = headerRight, opacity = opacity, animatedHeader = animatedHeader, tintColor = tintColor)
95
+ }
96
+ }
97
+
98
+ private fun getNavigationButtonConfig(
99
+ headerRight: HeaderRightData? = null,
100
+ isFavorite: Boolean = false,
101
+ onPressShortcut: () -> Unit,
102
+ onPressMore: () -> Unit
103
+ ): NavigationButtonConfig {
104
+ val totalTools = headerRight?.tools?.sumOf { it.items.size } ?: 0
105
+ var icon = if (isFavorite) "pin_star_checked" else "pin_star"
106
+ var onClickHandler = onPressShortcut
107
+ if (totalTools > 1 || headerRight?.useMore == true) {
108
+ icon = "navigation_more_icon"
109
+ onClickHandler = onPressMore
110
+ } else if (totalTools == 1 && !headerRight?.tools.isNullOrEmpty()) {
111
+ val singleTool = headerRight?.tools?.first()?.items?.firstOrNull()
112
+ if (singleTool != null) {
113
+ icon = singleTool.icon
114
+ onClickHandler = {
115
+ headerRight.toolCallback?.invoke(singleTool.key)
116
+ }
117
+ }
118
+ }
119
+ return NavigationButtonConfig(icon, onClickHandler)
120
+ }
121
+
122
+ @Composable
123
+ private fun ToolkitHeaderRight(
124
+ headerRight: HeaderRightData? = null,
125
+ opacity: Float = 1f,
126
+ animatedHeader: AnimatedHeader? = null,
127
+ tintColor: Color? = null
128
+ ) {
129
+ var isFavorite by remember { mutableStateOf(false) }
130
+ val isLoading by remember { mutableStateOf(false) }
131
+ val api = PlatformApi.current as? ComposeApi
132
+ val context = ApplicationContext.current
133
+
134
+ fun onPressShortcut() {
135
+ api?.request("onToolAction", mapOf("item" to mapOf("key" to "onFavorite"))) {
136
+ isFavorite = !isFavorite
137
+ }
138
+ }
139
+
140
+ fun onPressHelpCenter() {
141
+ val paramMap = mapOf(
142
+ "appId" to context?.appId,
143
+ "code" to context?.appCode,
144
+ "name" to context?.appName,
145
+ "icon" to context?.appIcon,
146
+ "description" to context?.description
147
+ )
148
+ api?.request("showHelpCenter", paramMap) {
149
+
150
+ }
151
+ }
152
+
153
+ fun onPressClose() {
154
+ api?.request("dismissAll", "", { _ -> })
155
+ }
156
+
157
+ fun onPressMore() {
158
+ api?.request(
159
+ "showTools",
160
+ mapOf(
161
+ "useSystemTools" to headerRight?.useSystemTools,
162
+ "tools" to headerRight?.tools?.map { it.toMap() },
163
+ "context" to mapOf(
164
+ "appId" to context?.appId,
165
+ "code" to context?.appCode,
166
+ "name" to context?.appName,
167
+ "icon" to context?.appIcon,
168
+ "description" to context?.description,
169
+ "support" to context?.support,
170
+ "toolkitConfig" to context?.toolkitConfig,
171
+ "providerId" to context?.providerId,
172
+ "permissions" to context?.permissions
173
+ )
174
+ )
175
+ ) { response ->
176
+ try {
177
+ val json = Json.parseToJsonElement(response).jsonObject
178
+ val toolResponse = json["response"]?.jsonPrimitive?.content
179
+ if (toolResponse != null) {
180
+ headerRight?.toolCallback?.invoke(toolResponse)
181
+ }
182
+ } catch (e: Exception) {
183
+ println("Error parsing response: $e")
184
+ }
185
+ }
186
+ }
187
+
188
+ val navButtonConfig = getNavigationButtonConfig(
189
+ headerRight,
190
+ isFavorite,
191
+ ::onPressShortcut,
192
+ ::onPressMore
193
+ )
194
+
195
+ val showBadge = headerRight?.tools?.any { group ->
196
+ group.items.any { it.showBadge }
197
+ }
198
+
199
+ val toolkitWidth = if (context !== null) 65.dp else 28.dp
200
+
201
+ var isShowShortcut = headerRight?.useShortcut == true
202
+
203
+ if (headerRight?.useMore == true && context == null) {
204
+ isShowShortcut = false
205
+ }
206
+
207
+ val color = getHeaderColor(animatedHeader, opacity, tintColor, AppTheme.current.colors.text.default)
208
+ val tintIconColor = color.tintIconColor
209
+ val backgroundButton = color.backgroundButton
210
+ val borderColor = color.borderColor
211
+
212
+ Row(
213
+ verticalAlignment = Alignment.CenterVertically
214
+ ) {
215
+ if (isShowShortcut) {
216
+ NavigationButton(
217
+ disabled = isLoading,
218
+ icon = navButtonConfig.icon,
219
+ showBadge = showBadge,
220
+ onClick = navButtonConfig.onPress,
221
+ tintColor = tintIconColor
222
+ )
223
+ }
224
+ Row(
225
+ verticalAlignment = Alignment.CenterVertically,
226
+ horizontalArrangement = Arrangement.Center,
227
+ modifier = Modifier
228
+ .padding(start = Spacing.S)
229
+ .border(0.2.dp, borderColor, shape = RoundedCornerShape(14.dp))
230
+ .width(toolkitWidth)
231
+ .height(28.dp)
232
+ .clip(shape = RoundedCornerShape(14.dp))
233
+ .background(backgroundButton)
234
+ ) {
235
+ if (context != null) {
236
+ Icon(
237
+ source = "help_center",
238
+ size = 20.dp,
239
+ color = tintIconColor,
240
+ modifier = Modifier.padding(4.dp).clickable {
241
+ onPressHelpCenter()
242
+ })
243
+ Box(
244
+ modifier = Modifier
245
+ .width(0.5.dp)
246
+ .height(12.dp)
247
+ .background(tintColor ?: Colors.black_20)
248
+ )
249
+ }
250
+
251
+ Icon(
252
+ source = "16_basic_home",
253
+ size = 20.dp,
254
+ color = tintIconColor,
255
+ modifier = Modifier.padding(4.dp).clickable { onPressClose() }
256
+ )
257
+ }
258
+ }
259
+ }
260
+
261
+ @Deprecated("Use vn.momo.kits.navigation.component instead", ReplaceWith("vn.momo.kits.navigation.component"))
262
+ @Composable
263
+ fun NavigationButton(
264
+ disabled: Boolean,
265
+ icon: String,
266
+ showBadge: Boolean? = false,
267
+ onClick: () -> Unit,
268
+ tintColor: Color?
269
+ ) {
270
+ val backgroundButton = if (tintColor == Colors.black_01) Colors.black_20.copy(alpha = 0.6f) else Colors.black_01.copy(alpha = 0.6f)
271
+ val borderColor = if (tintColor == Colors.black_01) Colors.black_01.copy(alpha = 0.2f) else Colors.black_20.copy(alpha = 0.2f)
272
+
273
+ Box(
274
+ modifier = Modifier
275
+ .size(28.dp)
276
+ .clickable(enabled = !disabled, onClick = onClick)
277
+ ) {
278
+ Box(
279
+ modifier = Modifier
280
+ .matchParentSize()
281
+ .clip(CircleShape)
282
+ .background(backgroundButton)
283
+ .border(0.2.dp, borderColor, CircleShape)
284
+ )
285
+ Box(
286
+ modifier = Modifier.matchParentSize(),
287
+ contentAlignment = Alignment.Center
288
+ ) {
289
+ Icon(
290
+ source = icon,
291
+ size = 20.dp,
292
+ color = tintColor
293
+ )
294
+ }
295
+
296
+ if (showBadge == true) {
297
+ BadgeDot(
298
+ size = DotSize.Small,
299
+ modifier = Modifier
300
+ .align(Alignment.TopEnd)
301
+ .offset(x = -Spacing.XXS, y = -Spacing.XXS)
302
+ )
303
+ }
304
+ }
305
+ }
@@ -0,0 +1,33 @@
1
+ package vn.momo.kits.application
2
+
3
+ import androidx.compose.runtime.Composable
4
+ import androidx.compose.ui.Modifier
5
+ import androidx.compose.ui.graphics.Color
6
+ import androidx.compose.ui.text.style.TextAlign
7
+ import androidx.compose.ui.text.style.TextOverflow
8
+ import androidx.compose.ui.unit.sp
9
+ import androidx.compose.ui.zIndex
10
+ import vn.momo.kits.components.Text
11
+ import vn.momo.kits.const.Typography
12
+
13
+ @Deprecated("Use vn.momo.kits.navigation.component instead", ReplaceWith("vn.momo.kits.navigation.component"))
14
+ @Composable
15
+ fun HeaderTitle(
16
+ title: String = "",
17
+ modifier: Modifier = Modifier,
18
+ textAlign: TextAlign = TextAlign.Start,
19
+ color: Color? = null,
20
+ ) {
21
+ Text(
22
+ modifier = Modifier.then(modifier).zIndex(1f),
23
+ text = title,
24
+ textAlign = textAlign,
25
+ style = Typography.actionSBold.copy(
26
+ fontSize = 15.sp,
27
+ lineHeight = 22.sp,
28
+ ),
29
+ color = color,
30
+ maxLines = 1,
31
+ overflow = TextOverflow.Ellipsis
32
+ )
33
+ }