jfs-components 0.1.0 → 0.1.8

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 (392) hide show
  1. package/CHANGELOG.md +37 -0
  2. package/lib/commonjs/components/AmountInput/AmountInput.js +8 -5
  3. package/lib/commonjs/components/AreaLineChart/AreaLineChart.js +1 -1
  4. package/lib/commonjs/components/Balance/Balance.js +17 -12
  5. package/lib/commonjs/components/BenefitCard/BenefitCard.js +231 -0
  6. package/lib/commonjs/components/Card/Card.js +2 -1
  7. package/lib/commonjs/components/CardFeedback/CardFeedback.js +2 -1
  8. package/lib/commonjs/components/CcCard/CcCard.js +470 -0
  9. package/lib/commonjs/components/Checkbox/Checkbox.js +6 -4
  10. package/lib/commonjs/components/CheckboxItem/CheckboxItem.js +4 -3
  11. package/lib/commonjs/components/CompareTable/CompareTable.js +372 -0
  12. package/lib/commonjs/components/ComparisonBar/ComparisonBar.js +266 -0
  13. package/lib/commonjs/components/Drawer/Drawer.js +13 -4
  14. package/lib/commonjs/components/DropdownInput/DropdownInput.js +36 -4
  15. package/lib/commonjs/components/FormField/FormField.js +4 -3
  16. package/lib/commonjs/components/FullscreenModal/FullscreenModal.js +62 -2
  17. package/lib/commonjs/components/Image/Image.js +11 -5
  18. package/lib/commonjs/components/InputSearch/InputSearch.js +6 -4
  19. package/lib/commonjs/components/LottiePlayer/loadNativeLottieView.js +8 -13
  20. package/lib/commonjs/components/NoteInput/NoteInput.js +6 -5
  21. package/lib/commonjs/components/Overlay/Overlay.js +92 -0
  22. package/lib/commonjs/components/PdpCcCard/PdpCcCard.js +273 -0
  23. package/lib/commonjs/components/PlanComparisonCard/PlanComparisonCard.js +2 -1
  24. package/lib/commonjs/components/ProductMerchandisingCard/GlassFill.js +263 -0
  25. package/lib/commonjs/components/ProductMerchandisingCard/GlassFill.web.js +116 -0
  26. package/lib/commonjs/components/ProductMerchandisingCard/ProductMerchandisingCard.js +353 -0
  27. package/lib/commonjs/components/ProjectionMarker/ProjectionMarker.js +161 -0
  28. package/lib/commonjs/components/Radio/Radio.js +5 -5
  29. package/lib/commonjs/components/Slider/Slider.js +473 -0
  30. package/lib/commonjs/components/TextInput/TextInput.js +15 -9
  31. package/lib/commonjs/components/TextSegment/TextSegment.js +118 -0
  32. package/lib/commonjs/components/docs/modeControls.js +116 -0
  33. package/lib/commonjs/components/index.js +70 -0
  34. package/lib/commonjs/design-tokens/Coin Variables-variables-full.json +1 -1
  35. package/lib/commonjs/design-tokens/JFSThemeProvider.js +1 -1
  36. package/lib/commonjs/design-tokens/figma-modes.generated.js +420 -0
  37. package/lib/commonjs/design-tokens/index.js +11 -0
  38. package/lib/commonjs/icons/registry.js +1 -1
  39. package/lib/commonjs/utils/react-utils.js +22 -0
  40. package/lib/module/components/Accordion/Accordion.js +1 -2
  41. package/lib/module/components/AmountInput/AmountInput.js +6 -4
  42. package/lib/module/components/AreaLineChart/AreaLineChart.js +1 -1
  43. package/lib/module/components/Balance/Balance.js +18 -13
  44. package/lib/module/components/BenefitCard/BenefitCard.js +225 -0
  45. package/lib/module/components/Card/Card.js +1 -2
  46. package/lib/module/components/CardFeedback/CardFeedback.js +1 -2
  47. package/lib/module/components/CcCard/CcCard.js +464 -0
  48. package/lib/module/components/Checkbox/Checkbox.js +6 -6
  49. package/lib/module/components/CheckboxItem/CheckboxItem.js +5 -4
  50. package/lib/module/components/CompareTable/CompareTable.js +367 -0
  51. package/lib/module/components/ComparisonBar/ComparisonBar.js +260 -0
  52. package/lib/module/components/Drawer/Drawer.js +12 -4
  53. package/lib/module/components/DropdownInput/DropdownInput.js +37 -5
  54. package/lib/module/components/FormField/FormField.js +5 -4
  55. package/lib/module/components/FullscreenModal/FullscreenModal.js +64 -5
  56. package/lib/module/components/Image/Image.js +11 -5
  57. package/lib/module/components/InputSearch/InputSearch.js +6 -4
  58. package/lib/module/components/InstitutionBadge/InstitutionBadge.js +1 -2
  59. package/lib/module/components/LottiePlayer/loadNativeLottieView.js +8 -13
  60. package/lib/module/components/MoneyValue/MoneyValue.js +1 -2
  61. package/lib/module/components/NoteInput/NoteInput.js +7 -6
  62. package/lib/module/components/OTP/OTP.js +1 -2
  63. package/lib/module/components/Overlay/Overlay.js +87 -0
  64. package/lib/module/components/PdpCcCard/PdpCcCard.js +267 -0
  65. package/lib/module/components/PlanComparisonCard/PlanComparisonCard.js +1 -2
  66. package/lib/module/components/PoweredByLabel/PoweredByLabel.js +1 -2
  67. package/lib/module/components/ProductMerchandisingCard/GlassFill.js +257 -0
  68. package/lib/module/components/ProductMerchandisingCard/GlassFill.web.js +111 -0
  69. package/lib/module/components/ProductMerchandisingCard/ProductMerchandisingCard.js +347 -0
  70. package/lib/module/components/ProjectionMarker/ProjectionMarker.js +156 -0
  71. package/lib/module/components/Radio/Radio.js +5 -4
  72. package/lib/module/components/RechargeCard/RechargeCard.js +1 -2
  73. package/lib/module/components/Section/Section.js +1 -2
  74. package/lib/module/components/Slider/Slider.js +468 -0
  75. package/lib/module/components/TextInput/TextInput.js +16 -12
  76. package/lib/module/components/TextSegment/TextSegment.js +113 -0
  77. package/lib/module/components/UpiHandle/UpiHandle.js +1 -2
  78. package/lib/module/components/docs/modeControls.js +111 -0
  79. package/lib/module/components/index.js +10 -0
  80. package/lib/module/design-tokens/Coin Variables-variables-full.json +1 -1
  81. package/lib/module/design-tokens/JFSThemeProvider.js +1 -1
  82. package/lib/module/design-tokens/figma-modes.generated.js +416 -0
  83. package/lib/module/design-tokens/index.js +2 -1
  84. package/lib/module/icons/registry.js +1 -1
  85. package/lib/module/utils/react-utils.js +21 -1
  86. package/lib/typescript/src/components/Accordion/Accordion.d.ts +2 -1
  87. package/lib/typescript/src/components/AccordionCheckbox/AccordionCheckbox.d.ts +2 -1
  88. package/lib/typescript/src/components/AccountCard/AccountCard.d.ts +2 -1
  89. package/lib/typescript/src/components/ActionFooter/ActionFooter.d.ts +2 -1
  90. package/lib/typescript/src/components/ActionTile/ActionTile.d.ts +2 -1
  91. package/lib/typescript/src/components/AllocationComparisonChart/AllocationComparisonChart.d.ts +2 -1
  92. package/lib/typescript/src/components/AmountInput/AmountInput.d.ts +5 -3
  93. package/lib/typescript/src/components/AppBar/AppBar.d.ts +2 -1
  94. package/lib/typescript/src/components/AreaLineChart/AreaLineChart.d.ts +3 -2
  95. package/lib/typescript/src/components/Attached/Attached.d.ts +2 -1
  96. package/lib/typescript/src/components/Avatar/Avatar.d.ts +2 -1
  97. package/lib/typescript/src/components/AvatarGroup/AvatarGroup.d.ts +2 -1
  98. package/lib/typescript/src/components/Badge/Badge.d.ts +2 -1
  99. package/lib/typescript/src/components/Balance/Balance.d.ts +2 -1
  100. package/lib/typescript/src/components/BenefitCard/BenefitCard.d.ts +93 -0
  101. package/lib/typescript/src/components/BottomNav/BottomNav.d.ts +2 -1
  102. package/lib/typescript/src/components/BottomNavItem/BottomNavItem.d.ts +2 -1
  103. package/lib/typescript/src/components/BrandChip/BrandChip.d.ts +2 -1
  104. package/lib/typescript/src/components/BubbleChart/BubbleChart.d.ts +2 -1
  105. package/lib/typescript/src/components/Button/Button.d.ts +2 -1
  106. package/lib/typescript/src/components/ButtonGroup/ButtonGroup.d.ts +2 -1
  107. package/lib/typescript/src/components/Card/Card.d.ts +3 -2
  108. package/lib/typescript/src/components/CardAdvisory/CardAdvisory.d.ts +2 -1
  109. package/lib/typescript/src/components/CardBankAccount/CardBankAccount.d.ts +2 -1
  110. package/lib/typescript/src/components/CardCTA/CardCTA.d.ts +2 -1
  111. package/lib/typescript/src/components/CardFeedback/CardFeedback.d.ts +7 -6
  112. package/lib/typescript/src/components/CardFinancialCondition/CardFinancialCondition.d.ts +2 -1
  113. package/lib/typescript/src/components/CardInsight/CardInsight.d.ts +2 -1
  114. package/lib/typescript/src/components/CardProviderInfo/CardProviderInfo.d.ts +2 -1
  115. package/lib/typescript/src/components/Carousel/Carousel.d.ts +4 -3
  116. package/lib/typescript/src/components/CcCard/CcCard.d.ts +137 -0
  117. package/lib/typescript/src/components/Checkbox/Checkbox.d.ts +5 -3
  118. package/lib/typescript/src/components/CheckboxGroup/CheckboxGroup.d.ts +2 -1
  119. package/lib/typescript/src/components/CheckboxItem/CheckboxItem.d.ts +4 -3
  120. package/lib/typescript/src/components/ChipGroup/ChipGroup.d.ts +2 -1
  121. package/lib/typescript/src/components/ChipSelect/ChipSelect.d.ts +2 -1
  122. package/lib/typescript/src/components/CircularProgressBar/CircularProgressBar.d.ts +2 -1
  123. package/lib/typescript/src/components/CircularProgressBarDoted/CircularProgressBarDoted.d.ts +2 -1
  124. package/lib/typescript/src/components/CircularRating/CircularRating.d.ts +2 -1
  125. package/lib/typescript/src/components/ClusterBubble/ClusterBubble.d.ts +2 -1
  126. package/lib/typescript/src/components/CompareTable/CompareTable.d.ts +88 -0
  127. package/lib/typescript/src/components/ComparisonBar/ComparisonBar.d.ts +118 -0
  128. package/lib/typescript/src/components/CoverageBarComparison/CoverageBarComparison.d.ts +3 -2
  129. package/lib/typescript/src/components/CoverageRing/CoverageRing.d.ts +2 -1
  130. package/lib/typescript/src/components/DebitCard/DebitCard.d.ts +2 -1
  131. package/lib/typescript/src/components/Disclaimer/Disclaimer.d.ts +2 -1
  132. package/lib/typescript/src/components/Divider/Divider.d.ts +2 -1
  133. package/lib/typescript/src/components/DonutChart/DonutChart.d.ts +4 -3
  134. package/lib/typescript/src/components/DonutChartSummary/DonutChartSummary.d.ts +3 -2
  135. package/lib/typescript/src/components/Drawer/Drawer.d.ts +15 -1
  136. package/lib/typescript/src/components/Dropdown/Dropdown.d.ts +3 -2
  137. package/lib/typescript/src/components/DropdownInput/DropdownInput.d.ts +22 -2
  138. package/lib/typescript/src/components/EmptyState/EmptyState.d.ts +2 -1
  139. package/lib/typescript/src/components/ExpandableCheckbox/ExpandableCheckbox.d.ts +2 -1
  140. package/lib/typescript/src/components/FilterBar/FilterBar.d.ts +3 -2
  141. package/lib/typescript/src/components/Form/Form.d.ts +2 -1
  142. package/lib/typescript/src/components/FormField/FormField.d.ts +4 -3
  143. package/lib/typescript/src/components/FullscreenModal/FullscreenModal.d.ts +2 -1
  144. package/lib/typescript/src/components/Gauge/Gauge.d.ts +2 -1
  145. package/lib/typescript/src/components/HStack/HStack.d.ts +2 -1
  146. package/lib/typescript/src/components/HoldingsCard/HoldingsCard.d.ts +2 -1
  147. package/lib/typescript/src/components/Icon/Icon.d.ts +2 -1
  148. package/lib/typescript/src/components/IconButton/IconButton.d.ts +2 -1
  149. package/lib/typescript/src/components/IconCapsule/IconCapsule.d.ts +2 -1
  150. package/lib/typescript/src/components/Image/Image.d.ts +17 -1
  151. package/lib/typescript/src/components/InputSearch/InputSearch.d.ts +25 -3
  152. package/lib/typescript/src/components/InstitutionBadge/InstitutionBadge.d.ts +2 -1
  153. package/lib/typescript/src/components/LazyList/LazyList.d.ts +2 -1
  154. package/lib/typescript/src/components/LinearMeter/LinearMeter.d.ts +3 -2
  155. package/lib/typescript/src/components/LinearProgress/LinearProgress.d.ts +2 -1
  156. package/lib/typescript/src/components/ListGroup/ListGroup.d.ts +2 -1
  157. package/lib/typescript/src/components/ListItem/ListItem.d.ts +2 -1
  158. package/lib/typescript/src/components/LottieIntroBlock/LottieIntroBlock.d.ts +2 -1
  159. package/lib/typescript/src/components/LottiePlayer/LottiePlayer.d.ts +2 -1
  160. package/lib/typescript/src/components/LottiePlayer/LottiePlayer.web.d.ts +2 -1
  161. package/lib/typescript/src/components/MediaCard/MediaCard.d.ts +6 -5
  162. package/lib/typescript/src/components/MerchantProfile/MerchantProfile.d.ts +2 -1
  163. package/lib/typescript/src/components/MessageField/MessageField.d.ts +2 -1
  164. package/lib/typescript/src/components/MetricLegendItem/MetricLegendItem.d.ts +2 -1
  165. package/lib/typescript/src/components/MoneyValue/MoneyValue.d.ts +2 -1
  166. package/lib/typescript/src/components/MonthlyStatusGrid/MonthlyStatusGrid.d.ts +4 -3
  167. package/lib/typescript/src/components/NavArrow/NavArrow.d.ts +2 -1
  168. package/lib/typescript/src/components/NoteInput/NoteInput.d.ts +21 -3
  169. package/lib/typescript/src/components/Nudge/Nudge.d.ts +2 -1
  170. package/lib/typescript/src/components/Numpad/Numpad.d.ts +2 -1
  171. package/lib/typescript/src/components/OTP/OTP.d.ts +3 -2
  172. package/lib/typescript/src/components/Overlay/Overlay.d.ts +52 -0
  173. package/lib/typescript/src/components/PageHero/PageHero.d.ts +2 -1
  174. package/lib/typescript/src/components/PaymentFeedback/PaymentFeedback.d.ts +2 -1
  175. package/lib/typescript/src/components/PdpCcCard/PdpCcCard.d.ts +84 -0
  176. package/lib/typescript/src/components/PlanComparisonCard/PlanComparisonCard.d.ts +2 -1
  177. package/lib/typescript/src/components/Popup/Popup.d.ts +2 -1
  178. package/lib/typescript/src/components/PortfolioHero/PortfolioHero.d.ts +2 -1
  179. package/lib/typescript/src/components/PoweredByLabel/PoweredByLabel.d.ts +2 -1
  180. package/lib/typescript/src/components/ProductLabel/ProductLabel.d.ts +2 -1
  181. package/lib/typescript/src/components/ProductMerchandisingCard/GlassFill.d.ts +56 -0
  182. package/lib/typescript/src/components/ProductMerchandisingCard/GlassFill.web.d.ts +27 -0
  183. package/lib/typescript/src/components/ProductMerchandisingCard/ProductMerchandisingCard.d.ts +81 -0
  184. package/lib/typescript/src/components/ProductOverview/ProductOverview.d.ts +2 -1
  185. package/lib/typescript/src/components/ProgressBadge/ProgressBadge.d.ts +2 -1
  186. package/lib/typescript/src/components/ProjectionMarker/ProjectionMarker.d.ts +82 -0
  187. package/lib/typescript/src/components/Radio/Radio.d.ts +5 -3
  188. package/lib/typescript/src/components/RadioButton/RadioButton.d.ts +2 -2
  189. package/lib/typescript/src/components/RangeTrack/RangeTrack.d.ts +3 -2
  190. package/lib/typescript/src/components/RechargeCard/RechargeCard.d.ts +2 -1
  191. package/lib/typescript/src/components/SavingsGoalSummary/SavingsGoalSummary.d.ts +2 -1
  192. package/lib/typescript/src/components/Screen/Screen.d.ts +2 -1
  193. package/lib/typescript/src/components/Section/Section.d.ts +3 -2
  194. package/lib/typescript/src/components/SegmentedControl/SegmentedControl.d.ts +2 -1
  195. package/lib/typescript/src/components/SegmentedTrack/SegmentedTrack.d.ts +4 -3
  196. package/lib/typescript/src/components/Slider/Slider.d.ts +99 -0
  197. package/lib/typescript/src/components/Slot/Slot.d.ts +2 -1
  198. package/lib/typescript/src/components/Spinner/Spinner.d.ts +2 -1
  199. package/lib/typescript/src/components/StatGroup/StatGroup.d.ts +2 -1
  200. package/lib/typescript/src/components/StatItem/StatItem.d.ts +2 -1
  201. package/lib/typescript/src/components/StatusHero/StatusHero.d.ts +2 -1
  202. package/lib/typescript/src/components/Stepper/Step.d.ts +2 -1
  203. package/lib/typescript/src/components/Stepper/StepLabel.d.ts +2 -1
  204. package/lib/typescript/src/components/Stepper/Stepper.d.ts +2 -1
  205. package/lib/typescript/src/components/StrengthIndicator/StrengthIndicator.d.ts +2 -1
  206. package/lib/typescript/src/components/SuggestiveSearch/SuggestiveSearch.d.ts +2 -1
  207. package/lib/typescript/src/components/SummaryTile/SummaryTile.d.ts +2 -1
  208. package/lib/typescript/src/components/SupportText/SupportText.d.ts +2 -1
  209. package/lib/typescript/src/components/SupportText/SupportTextIcon.d.ts +2 -1
  210. package/lib/typescript/src/components/SwappableAmount/SwappableAmount.d.ts +2 -1
  211. package/lib/typescript/src/components/Tabs/TabItem.d.ts +2 -1
  212. package/lib/typescript/src/components/Tabs/Tabs.d.ts +2 -1
  213. package/lib/typescript/src/components/TestimonialsCard/TestimonialsCard.d.ts +2 -1
  214. package/lib/typescript/src/components/Text/Text.d.ts +2 -1
  215. package/lib/typescript/src/components/TextInput/TextInput.d.ts +12 -31
  216. package/lib/typescript/src/components/TextSegment/TextSegment.d.ts +100 -0
  217. package/lib/typescript/src/components/ThreadHero/ThreadHero.d.ts +2 -1
  218. package/lib/typescript/src/components/Title/Title.d.ts +2 -1
  219. package/lib/typescript/src/components/Toast/Toast.d.ts +2 -1
  220. package/lib/typescript/src/components/Toast/ToastProvider.d.ts +2 -1
  221. package/lib/typescript/src/components/Toast/useToast.d.ts +3 -2
  222. package/lib/typescript/src/components/Toggle/Toggle.d.ts +2 -1
  223. package/lib/typescript/src/components/Tooltip/Tooltip.d.ts +2 -1
  224. package/lib/typescript/src/components/TransactionBubble/TransactionBubble.d.ts +2 -1
  225. package/lib/typescript/src/components/TransactionDetails/TransactionDetails.d.ts +3 -2
  226. package/lib/typescript/src/components/TransactionStatus/TransactionStatus.d.ts +2 -1
  227. package/lib/typescript/src/components/UpiHandle/UpiHandle.d.ts +2 -1
  228. package/lib/typescript/src/components/VStack/VStack.d.ts +2 -1
  229. package/lib/typescript/src/components/docs/modeControls.d.ts +28 -0
  230. package/lib/typescript/src/components/index.d.ts +11 -1
  231. package/lib/typescript/src/design-tokens/JFSThemeProvider.d.ts +4 -3
  232. package/lib/typescript/src/design-tokens/figma-modes.generated.d.ts +284 -0
  233. package/lib/typescript/src/design-tokens/index.d.ts +1 -0
  234. package/lib/typescript/src/icons/registry.d.ts +1 -1
  235. package/lib/typescript/src/skeleton/Skeleton.d.ts +2 -1
  236. package/lib/typescript/src/utils/react-utils.d.ts +12 -1
  237. package/package.json +4 -2
  238. package/src/components/Accordion/Accordion.tsx +2 -1
  239. package/src/components/AccordionCheckbox/AccordionCheckbox.tsx +2 -1
  240. package/src/components/AccountCard/AccountCard.tsx +2 -1
  241. package/src/components/ActionFooter/ActionFooter.tsx +2 -1
  242. package/src/components/ActionTile/ActionTile.tsx +2 -1
  243. package/src/components/AllocationComparisonChart/AllocationComparisonChart.tsx +2 -1
  244. package/src/components/AmountInput/AmountInput.tsx +9 -6
  245. package/src/components/AppBar/AppBar.tsx +2 -1
  246. package/src/components/AreaLineChart/AreaLineChart.tsx +8 -7
  247. package/src/components/Attached/Attached.tsx +2 -1
  248. package/src/components/Avatar/Avatar.tsx +3 -2
  249. package/src/components/AvatarGroup/AvatarGroup.tsx +2 -1
  250. package/src/components/Badge/Badge.tsx +2 -1
  251. package/src/components/Balance/Balance.tsx +18 -12
  252. package/src/components/BenefitCard/BenefitCard.tsx +309 -0
  253. package/src/components/BottomNav/BottomNav.tsx +2 -1
  254. package/src/components/BottomNavItem/BottomNavItem.tsx +3 -2
  255. package/src/components/BrandChip/BrandChip.tsx +3 -2
  256. package/src/components/BubbleChart/BubbleChart.tsx +2 -1
  257. package/src/components/Button/Button.tsx +3 -2
  258. package/src/components/ButtonGroup/ButtonGroup.tsx +2 -1
  259. package/src/components/Card/Card.tsx +4 -3
  260. package/src/components/CardAdvisory/CardAdvisory.tsx +3 -2
  261. package/src/components/CardBankAccount/CardBankAccount.tsx +2 -1
  262. package/src/components/CardCTA/CardCTA.tsx +3 -2
  263. package/src/components/CardFeedback/CardFeedback.tsx +11 -10
  264. package/src/components/CardFinancialCondition/CardFinancialCondition.tsx +3 -2
  265. package/src/components/CardInsight/CardInsight.tsx +2 -1
  266. package/src/components/CardProviderInfo/CardProviderInfo.tsx +2 -1
  267. package/src/components/Carousel/Carousel.tsx +5 -4
  268. package/src/components/CcCard/CcCard.tsx +598 -0
  269. package/src/components/Checkbox/Checkbox.tsx +7 -5
  270. package/src/components/CheckboxGroup/CheckboxGroup.tsx +2 -1
  271. package/src/components/CheckboxItem/CheckboxItem.tsx +7 -5
  272. package/src/components/ChipGroup/ChipGroup.tsx +2 -1
  273. package/src/components/ChipSelect/ChipSelect.tsx +2 -1
  274. package/src/components/CircularProgressBar/CircularProgressBar.tsx +2 -1
  275. package/src/components/CircularProgressBarDoted/CircularProgressBarDoted.tsx +2 -1
  276. package/src/components/CircularRating/CircularRating.tsx +3 -2
  277. package/src/components/ClusterBubble/ClusterBubble.tsx +2 -1
  278. package/src/components/CompareTable/CompareTable.tsx +477 -0
  279. package/src/components/ComparisonBar/ComparisonBar.tsx +356 -0
  280. package/src/components/CoverageBarComparison/CoverageBarComparison.tsx +3 -2
  281. package/src/components/CoverageRing/CoverageRing.tsx +2 -1
  282. package/src/components/DebitCard/DebitCard.tsx +2 -1
  283. package/src/components/Disclaimer/Disclaimer.tsx +2 -1
  284. package/src/components/Divider/Divider.tsx +2 -1
  285. package/src/components/DonutChart/DonutChart.tsx +6 -5
  286. package/src/components/DonutChartSummary/DonutChartSummary.tsx +3 -2
  287. package/src/components/Drawer/Drawer.tsx +21 -1
  288. package/src/components/Dropdown/Dropdown.tsx +4 -3
  289. package/src/components/DropdownInput/DropdownInput.tsx +60 -7
  290. package/src/components/EmptyState/EmptyState.tsx +2 -1
  291. package/src/components/ExpandableCheckbox/ExpandableCheckbox.tsx +2 -1
  292. package/src/components/FilterBar/FilterBar.tsx +3 -2
  293. package/src/components/Form/Form.tsx +2 -1
  294. package/src/components/FormField/FormField.tsx +8 -6
  295. package/src/components/FullscreenModal/FullscreenModal.tsx +68 -10
  296. package/src/components/Gauge/Gauge.tsx +2 -1
  297. package/src/components/HStack/HStack.tsx +2 -1
  298. package/src/components/HoldingsCard/HoldingsCard.tsx +2 -1
  299. package/src/components/Icon/Icon.tsx +3 -2
  300. package/src/components/IconButton/IconButton.tsx +3 -2
  301. package/src/components/IconCapsule/IconCapsule.tsx +3 -2
  302. package/src/components/Image/Image.tsx +29 -5
  303. package/src/components/InputSearch/InputSearch.tsx +11 -7
  304. package/src/components/InstitutionBadge/InstitutionBadge.tsx +3 -2
  305. package/src/components/LazyList/LazyList.tsx +2 -1
  306. package/src/components/LinearMeter/LinearMeter.tsx +3 -2
  307. package/src/components/LinearProgress/LinearProgress.tsx +2 -1
  308. package/src/components/ListGroup/ListGroup.tsx +2 -1
  309. package/src/components/ListItem/ListItem.tsx +3 -2
  310. package/src/components/LottieIntroBlock/LottieIntroBlock.tsx +2 -1
  311. package/src/components/LottiePlayer/LottiePlayer.tsx +3 -2
  312. package/src/components/LottiePlayer/LottiePlayer.web.tsx +3 -2
  313. package/src/components/LottiePlayer/loadNativeLottieView.tsx +9 -13
  314. package/src/components/MediaCard/MediaCard.tsx +7 -6
  315. package/src/components/MerchantProfile/MerchantProfile.tsx +2 -1
  316. package/src/components/MessageField/MessageField.tsx +3 -2
  317. package/src/components/MetricLegendItem/MetricLegendItem.tsx +2 -1
  318. package/src/components/MoneyValue/MoneyValue.tsx +2 -1
  319. package/src/components/MonthlyStatusGrid/MonthlyStatusGrid.tsx +5 -4
  320. package/src/components/NavArrow/NavArrow.tsx +3 -2
  321. package/src/components/NoteInput/NoteInput.tsx +10 -7
  322. package/src/components/Nudge/Nudge.tsx +3 -2
  323. package/src/components/Numpad/Numpad.tsx +2 -1
  324. package/src/components/OTP/OTP.tsx +3 -2
  325. package/src/components/Overlay/Overlay.tsx +114 -0
  326. package/src/components/PageHero/PageHero.tsx +2 -1
  327. package/src/components/PaymentFeedback/PaymentFeedback.tsx +2 -1
  328. package/src/components/PdpCcCard/PdpCcCard.tsx +356 -0
  329. package/src/components/PlanComparisonCard/PlanComparisonCard.tsx +2 -1
  330. package/src/components/Popup/Popup.tsx +2 -1
  331. package/src/components/PortfolioHero/PortfolioHero.tsx +2 -1
  332. package/src/components/PoweredByLabel/PoweredByLabel.tsx +2 -1
  333. package/src/components/ProductLabel/ProductLabel.tsx +2 -1
  334. package/src/components/ProductMerchandisingCard/GlassFill.tsx +276 -0
  335. package/src/components/ProductMerchandisingCard/GlassFill.web.tsx +127 -0
  336. package/src/components/ProductMerchandisingCard/ProductMerchandisingCard.tsx +423 -0
  337. package/src/components/ProductOverview/ProductOverview.tsx +2 -1
  338. package/src/components/ProgressBadge/ProgressBadge.tsx +2 -1
  339. package/src/components/ProjectionMarker/ProjectionMarker.tsx +277 -0
  340. package/src/components/Radio/Radio.tsx +7 -5
  341. package/src/components/RangeTrack/RangeTrack.tsx +3 -2
  342. package/src/components/RechargeCard/RechargeCard.tsx +2 -1
  343. package/src/components/SavingsGoalSummary/SavingsGoalSummary.tsx +2 -1
  344. package/src/components/Screen/Screen.tsx +2 -1
  345. package/src/components/Section/Section.tsx +6 -5
  346. package/src/components/SegmentedControl/SegmentedControl.tsx +3 -2
  347. package/src/components/SegmentedTrack/SegmentedTrack.tsx +5 -4
  348. package/src/components/Slider/Slider.tsx +628 -0
  349. package/src/components/Slot/Slot.tsx +2 -1
  350. package/src/components/Spinner/Spinner.tsx +2 -1
  351. package/src/components/StatGroup/StatGroup.tsx +3 -2
  352. package/src/components/StatItem/StatItem.tsx +2 -1
  353. package/src/components/StatusHero/StatusHero.tsx +2 -1
  354. package/src/components/Stepper/Step.tsx +2 -1
  355. package/src/components/Stepper/StepLabel.tsx +2 -1
  356. package/src/components/Stepper/Stepper.tsx +2 -1
  357. package/src/components/StrengthIndicator/StrengthIndicator.tsx +2 -1
  358. package/src/components/SuggestiveSearch/SuggestiveSearch.tsx +4 -3
  359. package/src/components/SummaryTile/SummaryTile.tsx +2 -1
  360. package/src/components/SupportText/SupportText.tsx +2 -1
  361. package/src/components/SupportText/SupportTextIcon.tsx +2 -1
  362. package/src/components/SwappableAmount/SwappableAmount.tsx +2 -1
  363. package/src/components/Tabs/TabItem.tsx +2 -1
  364. package/src/components/Tabs/Tabs.tsx +2 -1
  365. package/src/components/TestimonialsCard/TestimonialsCard.tsx +2 -1
  366. package/src/components/Text/Text.tsx +2 -1
  367. package/src/components/TextInput/TextInput.tsx +18 -13
  368. package/src/components/TextSegment/TextSegment.tsx +166 -0
  369. package/src/components/ThreadHero/ThreadHero.tsx +2 -1
  370. package/src/components/Title/Title.tsx +2 -1
  371. package/src/components/Toast/Toast.tsx +2 -1
  372. package/src/components/Toast/ToastProvider.tsx +2 -1
  373. package/src/components/Toast/useToast.ts +3 -2
  374. package/src/components/Toggle/Toggle.tsx +2 -1
  375. package/src/components/Tooltip/Tooltip.tsx +3 -2
  376. package/src/components/TransactionBubble/TransactionBubble.tsx +2 -1
  377. package/src/components/TransactionDetails/TransactionDetails.tsx +3 -2
  378. package/src/components/TransactionStatus/TransactionStatus.tsx +3 -2
  379. package/src/components/UpiHandle/UpiHandle.tsx +3 -2
  380. package/src/components/VStack/VStack.tsx +2 -1
  381. package/src/components/docs/modeControls.tsx +122 -0
  382. package/src/components/index.ts +11 -1
  383. package/src/design-tokens/Coin Variables-variables-full.json +1 -1
  384. package/src/design-tokens/JFSThemeProvider.tsx +4 -3
  385. package/src/design-tokens/figma-modes.generated.ts +425 -0
  386. package/src/design-tokens/index.ts +1 -0
  387. package/src/icons/registry.ts +1 -1
  388. package/src/skeleton/Skeleton.tsx +2 -1
  389. package/src/utils/react-utils.ts +26 -2
  390. package/lib/typescript/scripts/extract-component-tokens.d.ts +0 -9
  391. package/lib/typescript/scripts/generate-component-docs.d.ts +0 -9
  392. package/lib/typescript/scripts/generate-icon-registry.d.ts +0 -3
@@ -0,0 +1,356 @@
1
+ import React, { useMemo } from 'react'
2
+ import {
3
+ Pressable,
4
+ View,
5
+ type ImageSourcePropType,
6
+ type StyleProp,
7
+ type ViewStyle,
8
+ } from 'react-native'
9
+ import { getVariableByName } from '../../design-tokens/figma-variables-resolver'
10
+ import { useTokens } from '../../design-tokens/JFSThemeProvider'
11
+ import { EMPTY_MODES } from '../../utils/react-utils'
12
+ import { usePressableWebSupport } from '../../utils/web-platform-utils'
13
+ import Button from '../Button/Button'
14
+ import Image from '../Image/Image'
15
+ import IconCapsule from '../IconCapsule/IconCapsule'
16
+ import type { Modes } from '../../design-tokens'
17
+
18
+ /**
19
+ * A single slot in the {@link ComparisonBar}. Each item is either empty (the
20
+ * "Add" state — a tappable `+` capsule) or filled with an image (the
21
+ * "Image Added" state — the image plus a dismiss capsule in the corner).
22
+ *
23
+ * The presence of {@link ComparisonBarItem.imageSource} is what toggles the
24
+ * state: provide a source to show the image, leave it `undefined`/`null` to
25
+ * show the empty add slot. This keeps the component fully controlled — the
26
+ * `ComparisonBar` never owns the image state itself, so the consumer decides
27
+ * (e.g. after opening a file/asset picker) when and how an item flips between
28
+ * the two states.
29
+ */
30
+ export type ComparisonBarItem = {
31
+ /**
32
+ * Stable identifier for this slot. Returned to callbacks so the consumer
33
+ * can target the exact item that was interacted with. Falls back to the
34
+ * array index when omitted.
35
+ */
36
+ id?: string | number
37
+ /**
38
+ * Image to render in the slot. When provided the slot renders in the
39
+ * "Image Added" state; when omitted/`null` it renders the empty "Add" state.
40
+ * Accepts the same shapes as the library `Image` component (remote URL
41
+ * string, `{ uri }`, or a `require()`d asset).
42
+ */
43
+ imageSource?: ImageSourcePropType | string | null
44
+ /** Accessibility label for the slot. Defaults to a generic add/remove label. */
45
+ accessibilityLabel?: string
46
+ }
47
+
48
+ export type ComparisonBarProps = {
49
+ /**
50
+ * The slots rendered before the Compare button. Each entry controls its own
51
+ * add/image state via {@link ComparisonBarItem.imageSource}.
52
+ */
53
+ items: ComparisonBarItem[]
54
+ /**
55
+ * Fired when an empty (Add) slot is tapped. The consumer is expected to react
56
+ * by opening whatever picker is appropriate and then updating that item's
57
+ * `imageSource` to flip it into the "Image Added" state — the component does
58
+ * not know how images are sourced. Receives the item's `id` (or index when no
59
+ * id was supplied) and the slot index.
60
+ */
61
+ onItemPress?: (id: ComparisonBarItem['id'], index: number) => void
62
+ /**
63
+ * Fired when a filled slot is tapped. For better mobile ergonomics the
64
+ * *entire* filled slot is the remove target (the dismiss capsule is just a
65
+ * visual affordance), so a fingertip anywhere on the item triggers this. The
66
+ * consumer is expected to clear that item's `imageSource` to return it to the
67
+ * "Add" state. Receives the item's `id` (or index) and the slot index.
68
+ */
69
+ onItemRemove?: (id: ComparisonBarItem['id'], index: number) => void
70
+ /** Fired when the Compare button is pressed. */
71
+ onCompare?: () => void
72
+ /** Label for the trailing action button. Defaults to `"Compare"`. */
73
+ compareLabel?: string
74
+ /**
75
+ * Explicitly controls the Compare button's *functional* disabled state — a
76
+ * truly disabled button is non-interactive (its `onPress` never fires), not
77
+ * just dimmed. Note that `modes` only affects appearance, so dimming the
78
+ * button via tokens does NOT stop taps; that is what this prop is for.
79
+ *
80
+ * When provided (a boolean), it always wins over
81
+ * {@link ComparisonBarProps.disableCompareWhenEmpty}. Leave it `undefined`
82
+ * to fall back to the auto behavior.
83
+ */
84
+ compareDisabled?: boolean
85
+ /**
86
+ * When `true` (default) the Compare button is automatically (and truly)
87
+ * disabled while no slot has an image — there is nothing to compare yet. Set
88
+ * to `false` to keep it tappable even when empty. Ignored when
89
+ * {@link ComparisonBarProps.compareDisabled} is set explicitly.
90
+ */
91
+ disableCompareWhenEmpty?: boolean
92
+ /** Mode configuration passed to the token resolver. */
93
+ modes?: Modes
94
+ /** Style overrides for the outer floating card. */
95
+ style?: StyleProp<ViewStyle>
96
+ }
97
+
98
+ const ITEM_WIDTH = 45
99
+ const ITEM_HEIGHT = 44
100
+
101
+ interface ComparisonBarTokens {
102
+ card: ViewStyle
103
+ item: ViewStyle
104
+ itemImageState: ViewStyle
105
+ imageRadius: number
106
+ }
107
+
108
+ function resolveTokens(modes: Modes): ComparisonBarTokens {
109
+ const cardGap = (getVariableByName('compareFloatCard/gap', modes) ?? 12) as number
110
+ const cardPadH = (getVariableByName('compareFloatCard/padding/horizontal', modes) ?? 12) as number
111
+ const cardPadV = (getVariableByName('compareFloatCard/padding/vertical', modes) ?? 10) as number
112
+ const cardRadius = (getVariableByName('compareFloatCard/radius', modes) ?? 12) as number
113
+ const cardBackground = (getVariableByName('compareFloatCard/background', modes) ?? '#ffffff') as string
114
+ const cardBorderColor = (getVariableByName('compareFloatCard/border/color', modes) ?? '#f5f5f5') as string
115
+
116
+ const itemPadH = (getVariableByName('compareCardItem/padding/horizontal', modes) ?? 6) as number
117
+ const itemPadV = (getVariableByName('compareCardItem/padding/vertical', modes) ?? 8) as number
118
+ const itemRadius = (getVariableByName('compareCardItem/radius', modes) ?? 8) as number
119
+ const itemBackground = (getVariableByName('compareCardItem/background', modes) ?? '#ebebed') as string
120
+
121
+ const imageRadius = (getVariableByName('image/radius', modes) ?? 8) as number
122
+
123
+ return {
124
+ card: {
125
+ flexDirection: 'row',
126
+ alignItems: 'center',
127
+ gap: cardGap,
128
+ paddingHorizontal: cardPadH,
129
+ paddingVertical: cardPadV,
130
+ borderRadius: cardRadius,
131
+ borderWidth: 1,
132
+ borderColor: cardBorderColor,
133
+ backgroundColor: cardBackground,
134
+ alignSelf: 'flex-start',
135
+ },
136
+ item: {
137
+ width: ITEM_WIDTH,
138
+ height: ITEM_HEIGHT,
139
+ borderRadius: itemRadius,
140
+ backgroundColor: itemBackground,
141
+ paddingHorizontal: itemPadH,
142
+ paddingVertical: itemPadV,
143
+ alignItems: 'center',
144
+ justifyContent: 'center',
145
+ },
146
+ itemImageState: {
147
+ paddingHorizontal: itemPadH,
148
+ paddingVertical: itemPadV,
149
+ },
150
+ imageRadius,
151
+ }
152
+ }
153
+
154
+ type AdditemProps = {
155
+ item: ComparisonBarItem
156
+ index: number
157
+ tokens: ComparisonBarTokens
158
+ addCapsuleModes: Modes
159
+ closeCapsuleModes: Modes
160
+ onPress?: ComparisonBarProps['onItemPress']
161
+ onRemove?: ComparisonBarProps['onItemRemove']
162
+ }
163
+
164
+ /**
165
+ * Internal slot renderer for {@link ComparisonBar}. Intentionally NOT exported
166
+ * — it is meaningless outside of a `ComparisonBar` (its layout, sizing and
167
+ * remove affordance all assume the surrounding card) and is kept private so
168
+ * the public surface stays a single, cohesive component.
169
+ */
170
+ function Additem({ item, index, tokens, addCapsuleModes, closeCapsuleModes, onPress, onRemove }: AdditemProps) {
171
+ const hasImage = item.imageSource != null && item.imageSource !== ''
172
+ const id = item.id ?? index
173
+
174
+ const addWebProps = usePressableWebSupport({
175
+ restProps: {},
176
+ onPress: () => onPress?.(id, index),
177
+ disabled: false,
178
+ accessibilityLabel: item.accessibilityLabel ?? 'Add item to comparison',
179
+ })
180
+
181
+ const removeWebProps = usePressableWebSupport({
182
+ restProps: {},
183
+ onPress: () => onRemove?.(id, index),
184
+ disabled: false,
185
+ accessibilityLabel: item.accessibilityLabel ?? 'Remove item from comparison',
186
+ })
187
+
188
+ if (!hasImage) {
189
+ return (
190
+ <Pressable
191
+ style={tokens.item}
192
+ accessibilityRole="button"
193
+ accessibilityLabel={item.accessibilityLabel ?? 'Add item to comparison'}
194
+ onPress={() => onPress?.(id, index)}
195
+ {...addWebProps}
196
+ >
197
+ <IconCapsule iconName="ic_add" modes={addCapsuleModes} style={ADD_CAPSULE_STYLE} />
198
+ </Pressable>
199
+ )
200
+ }
201
+
202
+ // Mobile-first: the entire filled slot is the remove target, not just the
203
+ // tiny close capsule (which a fingertip struggles to hit). The capsule stays
204
+ // purely as a visual affordance and is marked non-interactive so it never
205
+ // intercepts the press from the surrounding Pressable.
206
+ return (
207
+ <Pressable
208
+ style={[tokens.item, tokens.itemImageState]}
209
+ accessibilityRole="button"
210
+ accessibilityLabel={item.accessibilityLabel ?? 'Remove item from comparison'}
211
+ onPress={() => onRemove?.(id, index)}
212
+ {...removeWebProps}
213
+ >
214
+ <Image
215
+ imageSource={item.imageSource as any}
216
+ width="100%"
217
+ height="100%"
218
+ borderRadius={tokens.imageRadius}
219
+ resizeMode="cover"
220
+ accessibilityLabel={item.accessibilityLabel ?? 'Comparison item image'}
221
+ />
222
+ <View style={CLOSE_CAPSULE_WRAPPER_STYLE} pointerEvents="none">
223
+ <IconCapsule iconName="ic_close" modes={closeCapsuleModes} />
224
+ </View>
225
+ </Pressable>
226
+ )
227
+ }
228
+
229
+ // The Add capsule is the transparent IconCapsule variant from Figma (the gray
230
+ // item box is the visible surface); its size/icon come from the resolved
231
+ // `Icon Capsule Size: S` tokens, we only flatten the background/border here.
232
+ const ADD_CAPSULE_STYLE: ViewStyle = {
233
+ backgroundColor: 'transparent',
234
+ borderColor: 'transparent',
235
+ }
236
+
237
+ // Positions the dismiss IconCapsule in the slot's top-right corner. The capsule
238
+ // itself (size/background/icon) is fully token-driven via `closeCapsuleModes`.
239
+ const CLOSE_CAPSULE_WRAPPER_STYLE: ViewStyle = {
240
+ position: 'absolute',
241
+ top: 1,
242
+ right: 1,
243
+ }
244
+
245
+ // Mode overrides applied on top of the consumer's `modes` for each capsule.
246
+ // These mirror the Figma component's IconCapsule variant selections so the
247
+ // sizing and colours come from design tokens instead of magic numbers.
248
+ const ADD_CAPSULE_MODE_OVERRIDES: Modes = { 'Icon Capsule Size': 'XS' }
249
+ const CLOSE_CAPSULE_MODE_OVERRIDES: Modes = {
250
+ AppearanceBrand: 'Neutral',
251
+ Emphasis: 'Medium',
252
+ 'Icon Capsule Size': 'XS',
253
+ }
254
+
255
+ /**
256
+ * ComparisonBar — a floating card that lets a user assemble a set of items to
257
+ * compare, then trigger the comparison.
258
+ *
259
+ * Each slot is fully controlled via its `imageSource`: an empty slot shows a
260
+ * tappable `+` (the "Add" state) and a filled slot shows the image with a
261
+ * dismiss capsule (the "Image Added" state). The component never sources or
262
+ * stores images itself — when an empty slot is pressed it fires `onItemPress`
263
+ * with the item's id/index so the consumer can open whatever picker is
264
+ * appropriate and then update that item's `imageSource` to flip its state.
265
+ * Tapping a filled slot (anywhere on it — a mobile-friendly hit target, with
266
+ * the dismiss capsule as a visual affordance) fires `onItemRemove` so the
267
+ * consumer can clear the source again.
268
+ *
269
+ * @example
270
+ * ```tsx
271
+ * const [items, setItems] = useState<ComparisonBarItem[]>([
272
+ * { id: 'a' }, { id: 'b' }, { id: 'c' }, { id: 'd' },
273
+ * ])
274
+ *
275
+ * <ComparisonBar
276
+ * items={items}
277
+ * onItemPress={async (id) => {
278
+ * const uri = await openImagePicker()
279
+ * setItems(prev => prev.map(it => it.id === id ? { ...it, imageSource: uri } : it))
280
+ * }}
281
+ * onItemRemove={(id) =>
282
+ * setItems(prev => prev.map(it => it.id === id ? { ...it, imageSource: null } : it))
283
+ * }
284
+ * onCompare={runComparison}
285
+ * />
286
+ * ```
287
+ */
288
+ function ComparisonBar({
289
+ items,
290
+ onItemPress,
291
+ onItemRemove,
292
+ onCompare,
293
+ compareLabel = 'Compare',
294
+ compareDisabled,
295
+ disableCompareWhenEmpty = true,
296
+ modes: propModes = EMPTY_MODES,
297
+ style,
298
+ }: ComparisonBarProps) {
299
+ const { modes: globalModes } = useTokens()
300
+ const modes = useMemo(
301
+ () =>
302
+ globalModes === EMPTY_MODES && propModes === EMPTY_MODES
303
+ ? EMPTY_MODES
304
+ : { ...globalModes, ...propModes },
305
+ [globalModes, propModes]
306
+ )
307
+
308
+ const tokens = useMemo(() => resolveTokens(modes), [modes])
309
+
310
+ // Capsule modes = consumer modes + this component's fixed IconCapsule variant
311
+ // selections. Memoized so each `Additem`'s `IconCapsule` keeps a stable
312
+ // `modes` identity and hits the resolver cache.
313
+ const addCapsuleModes = useMemo(
314
+ () => ({ ...modes, ...ADD_CAPSULE_MODE_OVERRIDES }),
315
+ [modes]
316
+ )
317
+ const closeCapsuleModes = useMemo(
318
+ () => ({ ...modes, ...CLOSE_CAPSULE_MODE_OVERRIDES }),
319
+ [modes]
320
+ )
321
+
322
+ // An explicit `compareDisabled` always wins (functional disable — the tap is
323
+ // truly blocked, not merely dimmed). Otherwise auto-disable while no slot has
324
+ // an image, since there is nothing to compare yet.
325
+ const hasAnyImage = useMemo(
326
+ () => items.some((it) => it.imageSource != null && it.imageSource !== ''),
327
+ [items]
328
+ )
329
+ const isCompareDisabled =
330
+ compareDisabled ?? (disableCompareWhenEmpty && !hasAnyImage)
331
+
332
+ return (
333
+ <View style={[tokens.card, style]}>
334
+ {items.map((item, index) => (
335
+ <Additem
336
+ key={item.id ?? index}
337
+ item={item}
338
+ index={index}
339
+ tokens={tokens}
340
+ addCapsuleModes={addCapsuleModes}
341
+ closeCapsuleModes={closeCapsuleModes}
342
+ onPress={onItemPress}
343
+ onRemove={onItemRemove}
344
+ />
345
+ ))}
346
+ <Button
347
+ label={compareLabel}
348
+ modes={modes}
349
+ disabled={isCompareDisabled}
350
+ {...(onCompare !== undefined ? { onPress: onCompare } : {})}
351
+ />
352
+ </View>
353
+ )
354
+ }
355
+
356
+ export default React.memo(ComparisonBar)
@@ -12,6 +12,7 @@ import { getVariableByName } from '../../design-tokens/figma-variables-resolver'
12
12
  import { useTokens } from '../../design-tokens/JFSThemeProvider'
13
13
  import { EMPTY_MODES } from '../../utils/react-utils'
14
14
  import MetricLegendItem from '../MetricLegendItem/MetricLegendItem'
15
+ import type { Modes } from '../../design-tokens'
15
16
 
16
17
  /**
17
18
  * One entry in the {@link CoverageBarComparisonProps.bars} array.
@@ -54,7 +55,7 @@ export type CoverageBarComparisonItem = {
54
55
  * Per-bar design token mode overrides. Merged on top of the parent `modes`
55
56
  * and the per-index `Emphasis / DataViz` defaults injected by the parent.
56
57
  */
57
- modes?: Record<string, any>
58
+ modes?: Modes
58
59
  /** Per-bar accessibility label. */
59
60
  accessibilityLabel?: string
60
61
  }
@@ -85,7 +86,7 @@ export type CoverageBarComparisonProps = {
85
86
  */
86
87
  legendGap?: number
87
88
  /** Design token modes for theming (e.g. `{ 'Color Mode': 'Light' }`). */
88
- modes?: Record<string, any>
89
+ modes?: Modes
89
90
  /** Container style override. */
90
91
  style?: StyleProp<ViewStyle>
91
92
  /** Style applied to the chart row (the bars container). */
@@ -10,6 +10,7 @@ import { useTokens } from '../../design-tokens/JFSThemeProvider'
10
10
  import { EMPTY_MODES, cloneChildrenWithModes } from '../../utils/react-utils'
11
11
  import Button, { type ButtonProps } from '../Button/Button'
12
12
  import CircularProgressBar from '../CircularProgressBar/CircularProgressBar'
13
+ import type { Modes } from '../../design-tokens'
13
14
 
14
15
  type CoverageRingBaseProps = Omit<
15
16
  React.ComponentProps<typeof View>,
@@ -73,7 +74,7 @@ export type CoverageRingProps = CoverageRingBaseProps & {
73
74
  */
74
75
  children?: React.ReactNode
75
76
  /** Design token modes forwarded to token lookups and slot children. */
76
- modes?: Record<string, any>
77
+ modes?: Modes
77
78
  /** Container style override. */
78
79
  style?: StyleProp<ViewStyle>
79
80
  /** Override the support-text style inside the ring. */
@@ -3,6 +3,7 @@ import { View, Text, Image, type ViewStyle, type TextStyle, type ImageStyle, typ
3
3
  import { getVariableByName } from '../../design-tokens/figma-variables-resolver'
4
4
  import { useTokens } from '../../design-tokens/JFSThemeProvider'
5
5
  import { cloneChildrenWithModes, EMPTY_MODES } from '../../utils/react-utils'
6
+ import type { Modes } from '../../design-tokens'
6
7
 
7
8
  const defaultCardArt = require('./cf64a67d5075caa8924d20b4e4e650d47b3ee08b.png')
8
9
 
@@ -24,7 +25,7 @@ export type DebitCardProps = {
24
25
  /** Slot: custom content for the provider logo area (right side of header, after cardType text) */
25
26
  providerLogoSlot?: React.ReactNode;
26
27
  /** Mode configuration for design token resolution */
27
- modes?: Record<string, any>;
28
+ modes?: Modes;
28
29
  /** Container style overrides */
29
30
  style?: StyleProp<ViewStyle>;
30
31
  };
@@ -3,10 +3,11 @@ import { View, Text, type StyleProp, type ViewStyle, type TextStyle } from 'reac
3
3
  import { getVariableByName } from '../../design-tokens/figma-variables-resolver'
4
4
  import { useTokens } from '../../design-tokens/JFSThemeProvider'
5
5
  import { EMPTY_MODES } from '../../utils/react-utils'
6
+ import type { Modes } from '../../design-tokens'
6
7
 
7
8
  type DisclaimerProps = {
8
9
  disclaimer?: string;
9
- modes?: Record<string, any>;
10
+ modes?: Modes;
10
11
  style?: StyleProp<ViewStyle>;
11
12
  textStyle?: StyleProp<TextStyle>;
12
13
  accessibilityLabel?: string;
@@ -6,6 +6,7 @@ import {
6
6
  } from 'react-native'
7
7
  import { getVariableByName } from '../../design-tokens/figma-variables-resolver'
8
8
  import { EMPTY_MODES } from '../../utils/react-utils'
9
+ import type { Modes } from '../../design-tokens'
9
10
 
10
11
  export type DividerDirection = 'horizontal' | 'vertical'
11
12
 
@@ -19,7 +20,7 @@ export type DividerProps = {
19
20
  /**
20
21
  * Mode configuration passed to the token resolver.
21
22
  */
22
- modes?: Record<string, any>
23
+ modes?: Modes
23
24
  /**
24
25
  * Optional style overrides for the divider
25
26
  */
@@ -11,6 +11,7 @@ import Svg, { Circle } from 'react-native-svg'
11
11
  import { getVariableByName } from '../../design-tokens/figma-variables-resolver'
12
12
  import { useTokens } from '../../design-tokens/JFSThemeProvider'
13
13
  import { EMPTY_MODES, flattenChildren } from '../../utils/react-utils'
14
+ import type { Modes } from '../../design-tokens'
14
15
 
15
16
  /**
16
17
  * Per-segment data definition for the data-driven `segments` prop.
@@ -32,7 +33,7 @@ export type DonutChartSegmentData = {
32
33
  * Per-segment design token mode overrides. Merged on top of parent
33
34
  * `modes` and the per-index `Appearance / DataViz` defaults.
34
35
  */
35
- modes?: Record<string, any>
36
+ modes?: Modes
36
37
  /** Per-segment accessibility label. */
37
38
  accessibilityLabel?: string
38
39
  }
@@ -73,7 +74,7 @@ export type DonutChartProps = {
73
74
  */
74
75
  gap?: number
75
76
  /** Design token modes for theming (e.g. `{ 'Color Mode': 'Light' }`). */
76
- modes?: Record<string, any>
77
+ modes?: Modes
77
78
  /** Override container styles. */
78
79
  style?: StyleProp<ViewStyle>
79
80
  /** Override default value text styles. */
@@ -142,7 +143,7 @@ function defaultAppearanceFor(index: number) {
142
143
  */
143
144
  function resolveSegmentColor(
144
145
  color: string | undefined,
145
- modes: Record<string, any>
146
+ modes: Modes
146
147
  ): string {
147
148
  if (color) return color
148
149
  return ((getVariableByName('dataViz/bg', modes) as string | null) ?? '#5d00b5')
@@ -176,7 +177,7 @@ type DonutChartSegmentProps = {
176
177
  * Design token modes for the segment. Merged with parent `modes` and
177
178
  * the per-index `Appearance / DataViz` defaults.
178
179
  */
179
- modes?: Record<string, any>
180
+ modes?: Modes
180
181
  /** Per-segment accessibility label. */
181
182
  accessibilityLabel?: string
182
183
  }
@@ -446,7 +447,7 @@ function buildArcs({
446
447
  totalValue: number
447
448
  circumference: number
448
449
  gapLength: number
449
- modes: Record<string, any>
450
+ modes: Modes
450
451
  }): ArcDescriptor[] {
451
452
  const arcs: ArcDescriptor[] = []
452
453
  const halfGap = gapLength / 2
@@ -5,6 +5,7 @@ import { useTokens } from '../../design-tokens/JFSThemeProvider'
5
5
  import { EMPTY_MODES } from '../../utils/react-utils'
6
6
  import DonutChart, { type DonutChartSegmentData } from '../DonutChart/DonutChart'
7
7
  import MetricLegendItem from '../MetricLegendItem/MetricLegendItem'
8
+ import type { Modes } from '../../design-tokens'
8
9
 
9
10
  /**
10
11
  * One row of the `DonutChartSummary`. Each item drives BOTH a donut
@@ -42,7 +43,7 @@ export type DonutChartSummaryItem = {
42
43
  * (`Senary`, `Primary`, `Secondary`, `Tertiary`, `Quaternary`,
43
44
  * `Quinary`, then cycles).
44
45
  */
45
- modes?: Record<string, any>
46
+ modes?: Modes
46
47
  /** Accessibility label for the segment + legend row pairing. */
47
48
  accessibilityLabel?: string
48
49
  }
@@ -80,7 +81,7 @@ export type DonutChartSummaryProps = {
80
81
  */
81
82
  donutGap?: number
82
83
  /** Design token modes for theming (e.g. `{ 'Color Mode': 'Light' }`). */
83
- modes?: Record<string, any>
84
+ modes?: Modes
84
85
  /** Override outer container styles. */
85
86
  style?: StyleProp<ViewStyle>
86
87
  /** Override the legend container styles. */
@@ -15,6 +15,8 @@ import Animated, {
15
15
  } from 'react-native-reanimated'
16
16
  import { getVariableByName } from '../../design-tokens/figma-variables-resolver'
17
17
  import { EMPTY_MODES } from '../../utils/react-utils'
18
+ import type { Modes } from '../../design-tokens'
19
+ import Overlay from '../Overlay/Overlay'
18
20
 
19
21
 
20
22
  const AnimatedScrollView = Animated.createAnimatedComponent(ScrollView)
@@ -54,7 +56,7 @@ function rubberBand(value: number, min: number, max: number, friction: number =
54
56
 
55
57
  export type DrawerProps = {
56
58
 
57
- modes?: Record<string, any>
59
+ modes?: Modes
58
60
  style?: import('react-native').StyleProp<import('react-native').ViewStyle>
59
61
  title?: string
60
62
  /**
@@ -95,6 +97,19 @@ export type DrawerProps = {
95
97
  * expanded), so parent components can react programmatically.
96
98
  */
97
99
  onStateChange?: (state: 'collapsed' | 'expanded') => void
100
+ /**
101
+ * When `true`, renders a full-screen semi-transparent {@link Overlay} scrim
102
+ * behind the drawer sheet (dimming everything else on screen). Defaults to
103
+ * `false`, in which case nothing is rendered behind the sheet and behaviour
104
+ * is unchanged.
105
+ */
106
+ showOverlay?: boolean
107
+ /**
108
+ * Called when the overlay scrim (the area outside the sheet) is pressed.
109
+ * Only relevant when `showOverlay` is `true` — typically used to collapse
110
+ * or dismiss the drawer.
111
+ */
112
+ onOverlayPress?: () => void
98
113
  }
99
114
 
100
115
  /**
@@ -132,6 +147,8 @@ function DrawerInner({
132
147
  showsVerticalScrollIndicator = false,
133
148
  bottomInset = 80,
134
149
  onStateChange,
150
+ showOverlay = false,
151
+ onOverlayPress,
135
152
  }: DrawerProps, ref: React.Ref<DrawerHandle>) {
136
153
  const { height: screenHeight } = useWindowDimensions()
137
154
 
@@ -439,6 +456,9 @@ function DrawerInner({
439
456
  // GestureHandlerRootView must wrap the app root; this overlay only needs to
440
457
  // let touches fall through where the sheet isn't.
441
458
  <View style={[styles.host, style]} pointerEvents="box-none">
459
+ {/* Full-screen scrim rendered beneath the sheet. Opt-in via `showOverlay`;
460
+ when disabled nothing renders here and touches still fall through. */}
461
+ {showOverlay ? <Overlay modes={modes} {...(onOverlayPress ? { onPress: onOverlayPress } : {})} /> : null}
442
462
  <GestureDetector gesture={gesture}>
443
463
  <Animated.View
444
464
  style={[
@@ -15,6 +15,7 @@ import { getVariableByName } from '../../design-tokens/figma-variables-resolver'
15
15
  import { useTokens } from '../../design-tokens/JFSThemeProvider'
16
16
  import { EMPTY_MODES, cloneChildrenWithModes } from '../../utils/react-utils'
17
17
  import Icon from '../../icons/Icon'
18
+ import type { Modes } from '../../design-tokens'
18
19
 
19
20
  const IS_WEB = Platform.OS === 'web'
20
21
 
@@ -47,7 +48,7 @@ export type DropdownItemProps = {
47
48
  /** Optional custom child content (overrides `label`). */
48
49
  children?: React.ReactNode
49
50
  /** Modes for design token resolution. */
50
- modes?: Record<string, any>
51
+ modes?: Modes
51
52
  /** Style overrides for the item container. */
52
53
  style?: StyleProp<ViewStyle>
53
54
  /** Style overrides for the item label text. */
@@ -58,7 +59,7 @@ export type DropdownItemProps = {
58
59
  accessibilityHint?: string
59
60
  }
60
61
 
61
- function useDropdownItemTokens(modes: Record<string, any>) {
62
+ function useDropdownItemTokens(modes: Modes) {
62
63
  return useMemo(() => {
63
64
  // The `dropdownItem/background` token aliases through the
64
65
  // `Dropdown Item State` collection (Idle | Selected), so we resolve
@@ -250,7 +251,7 @@ export type DropdownProps = {
250
251
  */
251
252
  maxHeight?: number
252
253
  /** Modes for design token resolution. */
253
- modes?: Record<string, any>
254
+ modes?: Modes
254
255
  /** Style overrides for the popup container. */
255
256
  style?: StyleProp<ViewStyle>
256
257
  /** Accessibility label for the menu surface. */