@momo-kits/native-kits 0.157.5 → 0.158.1-beta.1-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 (246) hide show
  1. package/.claude/settings.local.json +11 -0
  2. package/.claude/skills/design-system/SKILL.md +88 -0
  3. package/.claude/skills/design-system/references/components/avatar.md +134 -0
  4. package/.claude/skills/design-system/references/components/badge.md +127 -0
  5. package/.claude/skills/design-system/references/components/bottom-tab.md +177 -0
  6. package/.claude/skills/design-system/references/components/bottomsheet.md +170 -0
  7. package/.claude/skills/design-system/references/components/button.md +206 -0
  8. package/.claude/skills/design-system/references/components/carousel.md +117 -0
  9. package/.claude/skills/design-system/references/components/checkbox.md +98 -0
  10. package/.claude/skills/design-system/references/components/chip.md +146 -0
  11. package/.claude/skills/design-system/references/components/collapse.md +120 -0
  12. package/.claude/skills/design-system/references/components/date-picker.md +119 -0
  13. package/.claude/skills/design-system/references/components/divider.md +84 -0
  14. package/.claude/skills/design-system/references/components/icon.md +130 -0
  15. package/.claude/skills/design-system/references/components/image.md +81 -0
  16. package/.claude/skills/design-system/references/components/information.md +107 -0
  17. package/.claude/skills/design-system/references/components/input-dropdown.md +138 -0
  18. package/.claude/skills/design-system/references/components/input-money.md +157 -0
  19. package/.claude/skills/design-system/references/components/input-otp.md +132 -0
  20. package/.claude/skills/design-system/references/components/input-phone-number.md +140 -0
  21. package/.claude/skills/design-system/references/components/input-search.md +124 -0
  22. package/.claude/skills/design-system/references/components/input-text-area.md +133 -0
  23. package/.claude/skills/design-system/references/components/input.md +152 -0
  24. package/.claude/skills/design-system/references/components/loader.md +87 -0
  25. package/.claude/skills/design-system/references/components/pagination.md +105 -0
  26. package/.claude/skills/design-system/references/components/popup-notify.md +128 -0
  27. package/.claude/skills/design-system/references/components/progress-info.md +114 -0
  28. package/.claude/skills/design-system/references/components/radio.md +86 -0
  29. package/.claude/skills/design-system/references/components/rating.md +126 -0
  30. package/.claude/skills/design-system/references/components/skeleton.md +120 -0
  31. package/.claude/skills/design-system/references/components/slider.md +141 -0
  32. package/.claude/skills/design-system/references/components/snackbar.md +97 -0
  33. package/.claude/skills/design-system/references/components/stepper.md +100 -0
  34. package/.claude/skills/design-system/references/components/steps.md +91 -0
  35. package/.claude/skills/design-system/references/components/suggest-action.md +95 -0
  36. package/.claude/skills/design-system/references/components/swipe.md +121 -0
  37. package/.claude/skills/design-system/references/components/switch.md +98 -0
  38. package/.claude/skills/design-system/references/components/tab-view.md +120 -0
  39. package/.claude/skills/design-system/references/components/tag.md +118 -0
  40. package/.claude/skills/design-system/references/components/text.md +151 -0
  41. package/.claude/skills/design-system/references/components/toast.md +99 -0
  42. package/.claude/skills/design-system/references/components/tooltip.md +138 -0
  43. package/.claude/skills/design-system/references/components/top-nav-miniapp.md +94 -0
  44. package/.claude/skills/design-system/references/components/top-nav.md +226 -0
  45. package/.claude/skills/design-system/references/components/uploader.md +115 -0
  46. package/.claude/skills/design-system/references/navigation/bottom-tab.md +131 -0
  47. package/.claude/skills/design-system/references/navigation/bottomsheet.md +161 -0
  48. package/.claude/skills/design-system/references/navigation/modal.md +133 -0
  49. package/.claude/skills/design-system/references/navigation/navigation-options.md +225 -0
  50. package/.claude/skills/design-system/references/navigation/navigator.md +111 -0
  51. package/.claude/skills/design-system/references/navigation/setup.md +134 -0
  52. package/.claude/skills/design-system/references/navigation/stack.md +128 -0
  53. package/.claude/skills/design-system/references/spec-convention.md +80 -0
  54. package/.claude/skills/design-system/references/tokens/colors.md +131 -0
  55. package/.claude/skills/design-system/references/tokens/spacing-radius.md +144 -0
  56. package/.claude/skills/design-system/references/tokens/theme.md +125 -0
  57. package/.claude/skills/design-system/references/tokens/typography.md +135 -0
  58. package/.claude/skills/design-system-kits/SKILL.md +102 -0
  59. package/.claude/skills/design-system-kits/references/code-convention.md +118 -0
  60. package/.claude/skills/design-system-kits/references/components/avatar.md +45 -0
  61. package/.claude/skills/design-system-kits/references/components/badge.md +27 -0
  62. package/.claude/skills/design-system-kits/references/components/button.md +65 -0
  63. package/.claude/skills/design-system-kits/references/components/carousel.md +51 -0
  64. package/.claude/skills/design-system-kits/references/components/checkbox.md +39 -0
  65. package/.claude/skills/design-system-kits/references/components/chip.md +54 -0
  66. package/.claude/skills/design-system-kits/references/components/collapse.md +63 -0
  67. package/.claude/skills/design-system-kits/references/components/date-picker.md +36 -0
  68. package/.claude/skills/design-system-kits/references/components/divider.md +21 -0
  69. package/.claude/skills/design-system-kits/references/components/icon.md +382 -0
  70. package/.claude/skills/design-system-kits/references/components/image.md +62 -0
  71. package/.claude/skills/design-system-kits/references/components/information.md +61 -0
  72. package/.claude/skills/design-system-kits/references/components/input-dropdown.md +92 -0
  73. package/.claude/skills/design-system-kits/references/components/input-money.md +128 -0
  74. package/.claude/skills/design-system-kits/references/components/input-otp.md +85 -0
  75. package/.claude/skills/design-system-kits/references/components/input-phone-number.md +96 -0
  76. package/.claude/skills/design-system-kits/references/components/input-search.md +127 -0
  77. package/.claude/skills/design-system-kits/references/components/input-text-area.md +100 -0
  78. package/.claude/skills/design-system-kits/references/components/input.md +126 -0
  79. package/.claude/skills/design-system-kits/references/components/loader.md +41 -0
  80. package/.claude/skills/design-system-kits/references/components/pagination.md +47 -0
  81. package/.claude/skills/design-system-kits/references/components/popup-notify.md +69 -0
  82. package/.claude/skills/design-system-kits/references/components/popup-promotion.md +35 -0
  83. package/.claude/skills/design-system-kits/references/components/progress-info.md +55 -0
  84. package/.claude/skills/design-system-kits/references/components/radio.md +42 -0
  85. package/.claude/skills/design-system-kits/references/components/rating.md +36 -0
  86. package/.claude/skills/design-system-kits/references/components/skeleton.md +25 -0
  87. package/.claude/skills/design-system-kits/references/components/slider.md +53 -0
  88. package/.claude/skills/design-system-kits/references/components/snackbar.md +52 -0
  89. package/.claude/skills/design-system-kits/references/components/stepper.md +46 -0
  90. package/.claude/skills/design-system-kits/references/components/steps.md +57 -0
  91. package/.claude/skills/design-system-kits/references/components/suggest-action.md +44 -0
  92. package/.claude/skills/design-system-kits/references/components/swipe.md +44 -0
  93. package/.claude/skills/design-system-kits/references/components/switch.md +43 -0
  94. package/.claude/skills/design-system-kits/references/components/tab-view.md +56 -0
  95. package/.claude/skills/design-system-kits/references/components/tag.md +50 -0
  96. package/.claude/skills/design-system-kits/references/components/text.md +56 -0
  97. package/.claude/skills/design-system-kits/references/components/toast.md +51 -0
  98. package/.claude/skills/design-system-kits/references/components/tooltip.md +95 -0
  99. package/.claude/skills/design-system-kits/references/components/uploader.md +48 -0
  100. package/.claude/skills/design-system-kits/references/design-spec-structure.md +356 -0
  101. package/.claude/skills/design-system-kits/references/design-spec-to-code.md +596 -0
  102. package/.claude/skills/design-system-kits/references/navigation/bottom-tab.md +155 -0
  103. package/.claude/skills/design-system-kits/references/navigation/bottomsheet.md +94 -0
  104. package/.claude/skills/design-system-kits/references/navigation/modal.md +125 -0
  105. package/.claude/skills/design-system-kits/references/navigation/navigation-options.md +430 -0
  106. package/.claude/skills/design-system-kits/references/navigation/navigator.md +177 -0
  107. package/.claude/skills/design-system-kits/references/navigation/setup.md +94 -0
  108. package/.claude/skills/design-system-kits/references/navigation/stack.md +152 -0
  109. package/.claude/skills/design-system-kits/references/screen-layout-rule.md +125 -0
  110. package/.claude/skills/design-system-kits/references/tokens/colors.md +183 -0
  111. package/.claude/skills/design-system-kits/references/tokens/spacing-radius.md +45 -0
  112. package/.claude/skills/design-system-kits/references/tokens/theme.md +97 -0
  113. package/.claude/skills/design-system-kits/references/tokens/typography.md +105 -0
  114. package/.claude/skills/vibe-design/SKILL.md +306 -0
  115. package/build.gradle.kts +11 -0
  116. package/compose/build.gradle.kts +180 -0
  117. package/compose/build.gradle.kts.backup +180 -0
  118. package/compose/compose.podspec +54 -0
  119. package/compose/src/androidMain/kotlin/vn/momo/kits/platform/Platform.android.kt +117 -0
  120. package/compose/src/commonMain/composeResources/font/momosignature.otf +0 -0
  121. package/compose/src/commonMain/composeResources/font/momotrustdisplay.otf +0 -0
  122. package/compose/src/commonMain/composeResources/font/sfprotext_black.otf +0 -0
  123. package/compose/src/commonMain/composeResources/font/sfprotext_black.ttf +0 -0
  124. package/compose/src/commonMain/composeResources/font/sfprotext_bold.ttf +0 -0
  125. package/compose/src/commonMain/composeResources/font/sfprotext_heavy.ttf +0 -0
  126. package/compose/src/commonMain/composeResources/font/sfprotext_light.ttf +0 -0
  127. package/compose/src/commonMain/composeResources/font/sfprotext_medium.ttf +0 -0
  128. package/compose/src/commonMain/composeResources/font/sfprotext_regular.ttf +0 -0
  129. package/compose/src/commonMain/composeResources/font/sfprotext_semibold.ttf +0 -0
  130. package/compose/src/commonMain/composeResources/font/sfprotext_thin.otf +0 -0
  131. package/compose/src/commonMain/composeResources/font/sfprotext_thin.ttf +0 -0
  132. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.otf +0 -0
  133. package/compose/src/commonMain/composeResources/font/sfprotext_ultralight.ttf +0 -0
  134. package/compose/src/commonMain/kotlin/vn/momo/kits/application/AnimationSearchInput.kt +57 -0
  135. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Context.kt +107 -0
  136. package/compose/src/commonMain/kotlin/vn/momo/kits/application/FloatingButton.kt +201 -0
  137. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Header.kt +222 -0
  138. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderAnimated.kt +48 -0
  139. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderBackground.kt +86 -0
  140. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderDefault.kt +76 -0
  141. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderExtended.kt +76 -0
  142. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderRight.kt +305 -0
  143. package/compose/src/commonMain/kotlin/vn/momo/kits/application/HeaderTitle.kt +33 -0
  144. package/compose/src/commonMain/kotlin/vn/momo/kits/application/LiteScreen.kt +720 -0
  145. package/compose/src/commonMain/kotlin/vn/momo/kits/application/NavigationContainer.kt +121 -0
  146. package/compose/src/commonMain/kotlin/vn/momo/kits/application/Screen.kt +405 -0
  147. package/compose/src/commonMain/kotlin/vn/momo/kits/application/useHeaderSearchAnimation.kt +69 -0
  148. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Avatar.kt +157 -0
  149. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Badge.kt +85 -0
  150. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeDot.kt +32 -0
  151. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BadgeRibbon.kt +340 -0
  152. package/compose/src/commonMain/kotlin/vn/momo/kits/components/BaselineView.kt +198 -0
  153. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Button.kt +357 -0
  154. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Carousel.kt +123 -0
  155. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CheckBox.kt +94 -0
  156. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Chip.kt +136 -0
  157. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Collapse.kt +224 -0
  158. package/compose/src/commonMain/kotlin/vn/momo/kits/components/CupertinoOverscroll.kt +543 -0
  159. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Divider.kt +23 -0
  160. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Icon.kt +76 -0
  161. package/compose/src/commonMain/kotlin/vn/momo/kits/components/IconButton.kt +148 -0
  162. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Image.kt +188 -0
  163. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Information.kt +116 -0
  164. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Input.kt +448 -0
  165. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputDropDown.kt +172 -0
  166. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputMoney.kt +255 -0
  167. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputOTP.kt +231 -0
  168. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputPhoneNumber.kt +233 -0
  169. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputSearch.kt +254 -0
  170. package/compose/src/commonMain/kotlin/vn/momo/kits/components/InputTextArea.kt +241 -0
  171. package/compose/src/commonMain/kotlin/vn/momo/kits/components/LazyColumnWithBouncing.kt +364 -0
  172. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Loader.kt +108 -0
  173. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationDot.kt +56 -0
  174. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationNumber.kt +41 -0
  175. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationScroll.kt +92 -0
  176. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PaginationWhiteDot.kt +40 -0
  177. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupNotify.kt +352 -0
  178. package/compose/src/commonMain/kotlin/vn/momo/kits/components/PopupPromotion.kt +103 -0
  179. package/compose/src/commonMain/kotlin/vn/momo/kits/components/ProgressInfo.kt +338 -0
  180. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Radio.kt +70 -0
  181. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Rating.kt +87 -0
  182. package/compose/src/commonMain/kotlin/vn/momo/kits/components/ScaleSizeScope.kt +17 -0
  183. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Skeleton.kt +96 -0
  184. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Slider.kt +348 -0
  185. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Stepper.kt +256 -0
  186. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Steps.kt +494 -0
  187. package/compose/src/commonMain/kotlin/vn/momo/kits/components/SuggestAction.kt +131 -0
  188. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Swipe.kt +215 -0
  189. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Switch.kt +96 -0
  190. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TabView.kt +531 -0
  191. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tag.kt +92 -0
  192. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Text.kt +130 -0
  193. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Title.kt +214 -0
  194. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Tooltip.kt +590 -0
  195. package/compose/src/commonMain/kotlin/vn/momo/kits/components/TrustBanner.kt +177 -0
  196. package/compose/src/commonMain/kotlin/vn/momo/kits/components/Uploader.kt +192 -0
  197. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePicker.kt +205 -0
  198. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerTypes.kt +29 -0
  199. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/DateTimePickerUtils.kt +239 -0
  200. package/compose/src/commonMain/kotlin/vn/momo/kits/components/datetimepicker/WheelPicker.kt +191 -0
  201. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Colors.kt +306 -0
  202. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Radius.kt +12 -0
  203. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Spacing.kt +16 -0
  204. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Theme.kt +188 -0
  205. package/compose/src/commonMain/kotlin/vn/momo/kits/const/Typography.kt +285 -0
  206. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Card.kt +2 -0
  207. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Item.kt +35 -0
  208. package/compose/src/commonMain/kotlin/vn/momo/kits/layout/Section.kt +2 -0
  209. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/AutomationId.kt +50 -0
  210. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Clickable.kt +68 -0
  211. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Conditional.kt +11 -0
  212. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/DeprecatedModifier.kt +14 -0
  213. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Shadow.kt +50 -0
  214. package/compose/src/commonMain/kotlin/vn/momo/kits/modifier/Size.kt +51 -0
  215. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/BottomSheet.kt +239 -0
  216. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/ModalScreen.kt +119 -0
  217. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigation.kt +98 -0
  218. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/NavigationContainer.kt +161 -0
  219. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/Navigator.kt +331 -0
  220. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/StackScreen.kt +497 -0
  221. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTab.kt +162 -0
  222. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/BottomTabBar.kt +243 -0
  223. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/bottomtab/CurvedContainer.kt +86 -0
  224. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/FloatingButton.kt +187 -0
  225. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/Header.kt +279 -0
  226. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderBackground.kt +80 -0
  227. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderRight.kt +306 -0
  228. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderTitle.kt +32 -0
  229. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/HeaderUser.kt +370 -0
  230. package/compose/src/commonMain/kotlin/vn/momo/kits/navigation/component/SnackBar.kt +132 -0
  231. package/compose/src/commonMain/kotlin/vn/momo/kits/platform/Platform.kt +46 -0
  232. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Icons.kt +1329 -0
  233. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Resources.kt +62 -0
  234. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Tracking.kt +15 -0
  235. package/compose/src/commonMain/kotlin/vn/momo/kits/utils/Utils.kt +88 -0
  236. package/compose/src/iosMain/kotlin/vn/momo/kits/platform/Platform.ios.kt +161 -0
  237. package/gradle/libs.versions.toml +57 -0
  238. package/gradle/wrapper/gradle-wrapper.jar +0 -0
  239. package/gradle/wrapper/gradle-wrapper.properties +8 -0
  240. package/gradle.properties +26 -0
  241. package/gradlew +252 -0
  242. package/gradlew.bat +94 -0
  243. package/ios/Popup/PopupPromotion.swift +2 -2
  244. package/local.properties +8 -0
  245. package/package.json +1 -1
  246. package/settings.gradle.kts +52 -0
@@ -0,0 +1,130 @@
1
+ package vn.momo.kits.components
2
+
3
+ import androidx.compose.foundation.border
4
+ import androidx.compose.runtime.Composable
5
+ import androidx.compose.runtime.remember
6
+ import androidx.compose.ui.Modifier
7
+ import androidx.compose.ui.graphics.Color
8
+ import androidx.compose.ui.text.AnnotatedString
9
+ import androidx.compose.ui.text.TextLayoutResult
10
+ import androidx.compose.ui.text.TextStyle
11
+ import androidx.compose.ui.text.style.TextAlign
12
+ import androidx.compose.ui.text.style.TextDecoration
13
+ import androidx.compose.ui.text.style.TextOverflow
14
+ import androidx.compose.ui.unit.TextUnit
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.Typography
20
+ import vn.momo.kits.const.getFontFamily
21
+ import vn.momo.kits.const.scaleSize
22
+ import vn.momo.kits.modifier.conditional
23
+ import vn.momo.kits.modifier.setAutomationId
24
+
25
+ @Composable
26
+ fun Text(
27
+ text: String,
28
+ color: Color? = null,
29
+ style: TextStyle = Typography.bodyDefaultRegular,
30
+ textAlign: TextAlign? = TextAlign.Start,
31
+ modifier: Modifier = Modifier,
32
+ maxLines: Int = Int.MAX_VALUE,
33
+ overflow: TextOverflow = TextOverflow.Clip,
34
+ textDecoration: TextDecoration? = null,
35
+ onTextLayout: ((TextLayoutResult) -> Unit)? = null,
36
+ fontFamily: String? = null,
37
+ minLines: Int = 1,
38
+ letterSpacing: TextUnit = TextUnit.Unspecified,
39
+ softWrap: Boolean = true,
40
+ accessibilityId: String? = null
41
+ ) {
42
+ Text(
43
+ text = AnnotatedString(text),
44
+ color = color,
45
+ style = style,
46
+ textAlign = textAlign,
47
+ modifier = modifier,
48
+ maxLines = maxLines,
49
+ overflow = overflow,
50
+ textDecoration = textDecoration,
51
+ onTextLayout = onTextLayout,
52
+ fontFamily = fontFamily,
53
+ minLines = minLines,
54
+ letterSpacing = letterSpacing,
55
+ softWrap = softWrap,
56
+ accessibilityId = accessibilityId
57
+ )
58
+ }
59
+
60
+
61
+ @Composable
62
+ fun Text(
63
+ text: AnnotatedString,
64
+ color: Color? = null,
65
+ style: TextStyle = Typography.bodyDefaultRegular,
66
+ textAlign: TextAlign? = TextAlign.Start,
67
+ modifier: Modifier = Modifier,
68
+ maxLines: Int = Int.MAX_VALUE,
69
+ overflow: TextOverflow = TextOverflow.Clip,
70
+ textDecoration: TextDecoration? = null,
71
+ onTextLayout: ((TextLayoutResult) -> Unit)? = null,
72
+ fontFamily: String? = null,
73
+ minLines: Int = 1,
74
+ letterSpacing: TextUnit = TextUnit.Unspecified,
75
+ softWrap: Boolean = true,
76
+ accessibilityId: String? = null
77
+ ) {
78
+ // Cache theme access to avoid repeated lookups
79
+ val theme = AppTheme.current
80
+
81
+ // Call @Composable functions directly in composable context
82
+ val scaledFontSize = scaleSize(style.fontSize)
83
+ val scaledLineHeight = scaleSize(style.lineHeight)
84
+ val fontFamilyResult = getFontFamily(fontFamily ?: theme.font, style.fontWeight)
85
+
86
+ // Now memoize the results
87
+ val fontSize = remember(scaledFontSize) { scaledFontSize }
88
+ val lineHeight = remember(scaledLineHeight) { scaledLineHeight }
89
+ val font = remember(fontFamilyResult) { fontFamilyResult }
90
+
91
+ // Memoize color calculation
92
+ val textColor = remember(color, theme) {
93
+ color ?: theme.colors.text.default
94
+ }
95
+
96
+ // Memoize style copy operation
97
+ val optimizedStyle = remember(style) {
98
+ style.copy(
99
+ fontWeight = null,
100
+ lineHeight = if (lineHeight.value.isFinite() && lineHeight.value > 0) lineHeight else style.lineHeight
101
+ )
102
+ }
103
+
104
+ // Memoize automation ID
105
+ val automationId = remember(accessibilityId, text) {
106
+ accessibilityId ?: text
107
+ }
108
+
109
+ // on/off baseline config value, default will be false
110
+
111
+ androidx.compose.material3.Text(
112
+ modifier = modifier.conditional(IsShowBaseLineDebug){
113
+ border(1.dp, Colors.blue_03)
114
+ }.setAutomationId(automationId.toString()),
115
+ text = text,
116
+ color = textColor,
117
+ style = optimizedStyle,
118
+ textAlign = textAlign,
119
+ fontSize = fontSize,
120
+ fontFamily = font,
121
+ maxLines = maxLines,
122
+ softWrap = softWrap,
123
+ letterSpacing = letterSpacing,
124
+ minLines = minLines,
125
+ textDecoration = textDecoration,
126
+ onTextLayout = onTextLayout ?: {},
127
+ overflow = overflow
128
+ )
129
+ }
130
+
@@ -0,0 +1,214 @@
1
+ package vn.momo.kits.components
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.Column
9
+ import androidx.compose.foundation.layout.IntrinsicSize
10
+ import androidx.compose.foundation.layout.Row
11
+ import androidx.compose.foundation.layout.Spacer
12
+ import androidx.compose.foundation.layout.fillMaxHeight
13
+ import androidx.compose.foundation.layout.fillMaxWidth
14
+ import androidx.compose.foundation.layout.height
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.ui.Alignment
21
+ import androidx.compose.ui.Modifier
22
+ import androidx.compose.ui.graphics.Color
23
+ import androidx.compose.ui.text.TextStyle
24
+ import androidx.compose.ui.text.font.FontWeight
25
+ import androidx.compose.ui.unit.dp
26
+ import androidx.compose.ui.unit.sp
27
+ import vn.momo.kits.application.IsShowBaseLineDebug
28
+ import vn.momo.kits.const.AppTheme
29
+ import vn.momo.kits.const.Colors
30
+ import vn.momo.kits.const.Spacing
31
+ import vn.momo.kits.const.Typography
32
+ import vn.momo.kits.modifier.conditional
33
+
34
+ enum class TitleType { Card, Section }
35
+ enum class TitleSize { Small, Medium, Large }
36
+ enum class IconAlign { Top, Center, Bottom }
37
+ enum class ButtonSize { Small, Large }
38
+
39
+ @Composable
40
+ fun Title(
41
+ title: String,
42
+ type: TitleType = TitleType.Section,
43
+ size: TitleSize = TitleSize.Medium,
44
+ icon: String? = null,
45
+ iconColor: Color? = null,
46
+ iconAlign: IconAlign = IconAlign.Top,
47
+ showRightAction: Boolean = false,
48
+ showTrailingAction: Boolean = false,
49
+ badgeLabel: String? = null,
50
+ buttonTitle: String? = null,
51
+ buttonSize: ButtonSize = ButtonSize.Small,
52
+ onPressRightAction: () -> Unit = {},
53
+ onPressTrailingAction: () -> Unit = {},
54
+ textOnly: Boolean = false,
55
+ description: String? = null,
56
+ modifier: Modifier = Modifier
57
+ ) {
58
+ val theme = AppTheme.current
59
+ val textStyle: TextStyle = when (type) {
60
+ TitleType.Card -> when (size) {
61
+ TitleSize.Small -> TextStyle(fontSize = 14.sp, lineHeight = 20.sp)
62
+ TitleSize.Medium -> TextStyle(fontSize = 16.sp, lineHeight = 22.sp)
63
+ TitleSize.Large -> TextStyle(fontSize = 18.sp, lineHeight = 26.sp)
64
+ }
65
+
66
+ TitleType.Section -> when (size) {
67
+ TitleSize.Small -> TextStyle(
68
+ fontSize = 16.sp,
69
+ lineHeight = 24.sp,
70
+ fontWeight = FontWeight.Bold
71
+ )
72
+
73
+ TitleSize.Medium -> TextStyle(
74
+ fontSize = 18.sp,
75
+ lineHeight = 26.sp,
76
+ fontWeight = FontWeight.Bold
77
+ )
78
+
79
+ TitleSize.Large -> TextStyle(
80
+ fontSize = 20.sp,
81
+ lineHeight = 28.sp,
82
+ fontWeight = FontWeight.Bold
83
+ )
84
+ }
85
+ }
86
+
87
+ if (textOnly) {
88
+ Text(
89
+ text = title,
90
+ style = textStyle,
91
+ modifier = modifier
92
+ )
93
+ return
94
+ }
95
+
96
+ Row(
97
+ modifier = modifier
98
+ .fillMaxWidth()
99
+ .height(IntrinsicSize.Min)
100
+ .conditional(IsShowBaseLineDebug) {
101
+ border(1.dp, Colors.blue_03)
102
+ }
103
+ .padding(8.dp),
104
+ verticalAlignment = Alignment.CenterVertically
105
+ ) {
106
+ icon?.let {
107
+ Column(
108
+ modifier = Modifier.fillMaxHeight().padding(end = Spacing.S),
109
+ verticalArrangement = when (iconAlign) {
110
+ IconAlign.Top -> Arrangement.Top
111
+ IconAlign.Center -> Arrangement.Center
112
+ IconAlign.Bottom -> Arrangement.Bottom
113
+ },
114
+ ) {
115
+ // Icon
116
+ Icon(
117
+ source = it,
118
+ color = iconColor ?: theme.colors.text.default,
119
+ modifier = Modifier.size(24.dp)
120
+ )
121
+ }
122
+ }
123
+
124
+ Column(
125
+ modifier = Modifier.weight(1f)
126
+ ) {
127
+ Row(
128
+ verticalAlignment = Alignment.CenterVertically
129
+ ) {
130
+ Row(
131
+ verticalAlignment = Alignment.CenterVertically,
132
+ modifier = if (showTrailingAction) Modifier else Modifier.weight(1f),
133
+ ) {
134
+ Text(
135
+ text = title,
136
+ style = textStyle,
137
+ maxLines = if (showTrailingAction || badgeLabel != null) 1 else 2,
138
+ )
139
+
140
+ // Badge
141
+ badgeLabel?.let {
142
+ Spacer(modifier = Modifier.width(4.dp))
143
+ Badge(
144
+ label = it
145
+ )
146
+ }
147
+
148
+ }
149
+
150
+ // Trailing action (icon)
151
+ if (showTrailingAction && !showRightAction) {
152
+ Spacer(modifier = Modifier.width(8.dp))
153
+ Box(
154
+ modifier = Modifier
155
+ .size(24.dp)
156
+ .background(
157
+ color = if (type == TitleType.Section) Colors.black_06.copy(0.6f) else Colors.black_06.copy(
158
+ 0.3f
159
+ ),
160
+ shape = RoundedCornerShape(12.dp)
161
+ )
162
+ .clickable { onPressTrailingAction() },
163
+ contentAlignment = Alignment.Center
164
+ ) {
165
+ Icon(
166
+ source = "arrow_chevron_right_small",
167
+ size = 18.dp
168
+ )
169
+ }
170
+ }
171
+ }
172
+
173
+ // Description
174
+ description?.let {
175
+ Spacer(modifier = Modifier.height(4.dp))
176
+ Text(
177
+ text = it,
178
+ style = Typography.descriptionDefaultRegular,
179
+ color = theme.colors.text.secondary
180
+ )
181
+ }
182
+ }
183
+
184
+ // Right action (button or icon)
185
+ if (showRightAction && !showTrailingAction) {
186
+ Spacer(modifier = Modifier.width(8.dp))
187
+ if (buttonTitle != null) {
188
+ Text(
189
+ text = buttonTitle,
190
+ style = if (buttonSize === ButtonSize.Small) Typography.actionXsBold else Typography.actionSBold,
191
+ color = theme.colors.primary,
192
+ modifier = Modifier.clickable { onPressRightAction() }
193
+ )
194
+ } else {
195
+ Box(
196
+ modifier = Modifier
197
+ .size(24.dp)
198
+ .background(
199
+ color = Colors.pink_03.copy(alpha = 0.1f),
200
+ shape = RoundedCornerShape(12.dp)
201
+ )
202
+ .clickable { onPressRightAction() },
203
+ contentAlignment = Alignment.Center
204
+ ) {
205
+ Icon(
206
+ source = "arrow_chevron_right_small",
207
+ modifier = Modifier.size(22.dp),
208
+ color = theme.colors.primary
209
+ )
210
+ }
211
+ }
212
+ }
213
+ }
214
+ }