@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,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
+ }