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.
- package/CHANGELOG.md +37 -0
- package/lib/commonjs/components/AmountInput/AmountInput.js +8 -5
- package/lib/commonjs/components/AreaLineChart/AreaLineChart.js +1 -1
- package/lib/commonjs/components/Balance/Balance.js +17 -12
- package/lib/commonjs/components/BenefitCard/BenefitCard.js +231 -0
- package/lib/commonjs/components/Card/Card.js +2 -1
- package/lib/commonjs/components/CardFeedback/CardFeedback.js +2 -1
- package/lib/commonjs/components/CcCard/CcCard.js +470 -0
- package/lib/commonjs/components/Checkbox/Checkbox.js +6 -4
- package/lib/commonjs/components/CheckboxItem/CheckboxItem.js +4 -3
- package/lib/commonjs/components/CompareTable/CompareTable.js +372 -0
- package/lib/commonjs/components/ComparisonBar/ComparisonBar.js +266 -0
- package/lib/commonjs/components/Drawer/Drawer.js +13 -4
- package/lib/commonjs/components/DropdownInput/DropdownInput.js +36 -4
- package/lib/commonjs/components/FormField/FormField.js +4 -3
- package/lib/commonjs/components/FullscreenModal/FullscreenModal.js +62 -2
- package/lib/commonjs/components/Image/Image.js +11 -5
- package/lib/commonjs/components/InputSearch/InputSearch.js +6 -4
- package/lib/commonjs/components/LottiePlayer/loadNativeLottieView.js +8 -13
- package/lib/commonjs/components/NoteInput/NoteInput.js +6 -5
- package/lib/commonjs/components/Overlay/Overlay.js +92 -0
- package/lib/commonjs/components/PdpCcCard/PdpCcCard.js +273 -0
- package/lib/commonjs/components/PlanComparisonCard/PlanComparisonCard.js +2 -1
- package/lib/commonjs/components/ProductMerchandisingCard/GlassFill.js +263 -0
- package/lib/commonjs/components/ProductMerchandisingCard/GlassFill.web.js +116 -0
- package/lib/commonjs/components/ProductMerchandisingCard/ProductMerchandisingCard.js +353 -0
- package/lib/commonjs/components/ProjectionMarker/ProjectionMarker.js +161 -0
- package/lib/commonjs/components/Radio/Radio.js +5 -5
- package/lib/commonjs/components/Slider/Slider.js +473 -0
- package/lib/commonjs/components/TextInput/TextInput.js +15 -9
- package/lib/commonjs/components/TextSegment/TextSegment.js +118 -0
- package/lib/commonjs/components/docs/modeControls.js +116 -0
- package/lib/commonjs/components/index.js +70 -0
- package/lib/commonjs/design-tokens/Coin Variables-variables-full.json +1 -1
- package/lib/commonjs/design-tokens/JFSThemeProvider.js +1 -1
- package/lib/commonjs/design-tokens/figma-modes.generated.js +420 -0
- package/lib/commonjs/design-tokens/index.js +11 -0
- package/lib/commonjs/icons/registry.js +1 -1
- package/lib/commonjs/utils/react-utils.js +22 -0
- package/lib/module/components/Accordion/Accordion.js +1 -2
- package/lib/module/components/AmountInput/AmountInput.js +6 -4
- package/lib/module/components/AreaLineChart/AreaLineChart.js +1 -1
- package/lib/module/components/Balance/Balance.js +18 -13
- package/lib/module/components/BenefitCard/BenefitCard.js +225 -0
- package/lib/module/components/Card/Card.js +1 -2
- package/lib/module/components/CardFeedback/CardFeedback.js +1 -2
- package/lib/module/components/CcCard/CcCard.js +464 -0
- package/lib/module/components/Checkbox/Checkbox.js +6 -6
- package/lib/module/components/CheckboxItem/CheckboxItem.js +5 -4
- package/lib/module/components/CompareTable/CompareTable.js +367 -0
- package/lib/module/components/ComparisonBar/ComparisonBar.js +260 -0
- package/lib/module/components/Drawer/Drawer.js +12 -4
- package/lib/module/components/DropdownInput/DropdownInput.js +37 -5
- package/lib/module/components/FormField/FormField.js +5 -4
- package/lib/module/components/FullscreenModal/FullscreenModal.js +64 -5
- package/lib/module/components/Image/Image.js +11 -5
- package/lib/module/components/InputSearch/InputSearch.js +6 -4
- package/lib/module/components/InstitutionBadge/InstitutionBadge.js +1 -2
- package/lib/module/components/LottiePlayer/loadNativeLottieView.js +8 -13
- package/lib/module/components/MoneyValue/MoneyValue.js +1 -2
- package/lib/module/components/NoteInput/NoteInput.js +7 -6
- package/lib/module/components/OTP/OTP.js +1 -2
- package/lib/module/components/Overlay/Overlay.js +87 -0
- package/lib/module/components/PdpCcCard/PdpCcCard.js +267 -0
- package/lib/module/components/PlanComparisonCard/PlanComparisonCard.js +1 -2
- package/lib/module/components/PoweredByLabel/PoweredByLabel.js +1 -2
- package/lib/module/components/ProductMerchandisingCard/GlassFill.js +257 -0
- package/lib/module/components/ProductMerchandisingCard/GlassFill.web.js +111 -0
- package/lib/module/components/ProductMerchandisingCard/ProductMerchandisingCard.js +347 -0
- package/lib/module/components/ProjectionMarker/ProjectionMarker.js +156 -0
- package/lib/module/components/Radio/Radio.js +5 -4
- package/lib/module/components/RechargeCard/RechargeCard.js +1 -2
- package/lib/module/components/Section/Section.js +1 -2
- package/lib/module/components/Slider/Slider.js +468 -0
- package/lib/module/components/TextInput/TextInput.js +16 -12
- package/lib/module/components/TextSegment/TextSegment.js +113 -0
- package/lib/module/components/UpiHandle/UpiHandle.js +1 -2
- package/lib/module/components/docs/modeControls.js +111 -0
- package/lib/module/components/index.js +10 -0
- package/lib/module/design-tokens/Coin Variables-variables-full.json +1 -1
- package/lib/module/design-tokens/JFSThemeProvider.js +1 -1
- package/lib/module/design-tokens/figma-modes.generated.js +416 -0
- package/lib/module/design-tokens/index.js +2 -1
- package/lib/module/icons/registry.js +1 -1
- package/lib/module/utils/react-utils.js +21 -1
- package/lib/typescript/src/components/Accordion/Accordion.d.ts +2 -1
- package/lib/typescript/src/components/AccordionCheckbox/AccordionCheckbox.d.ts +2 -1
- package/lib/typescript/src/components/AccountCard/AccountCard.d.ts +2 -1
- package/lib/typescript/src/components/ActionFooter/ActionFooter.d.ts +2 -1
- package/lib/typescript/src/components/ActionTile/ActionTile.d.ts +2 -1
- package/lib/typescript/src/components/AllocationComparisonChart/AllocationComparisonChart.d.ts +2 -1
- package/lib/typescript/src/components/AmountInput/AmountInput.d.ts +5 -3
- package/lib/typescript/src/components/AppBar/AppBar.d.ts +2 -1
- package/lib/typescript/src/components/AreaLineChart/AreaLineChart.d.ts +3 -2
- package/lib/typescript/src/components/Attached/Attached.d.ts +2 -1
- package/lib/typescript/src/components/Avatar/Avatar.d.ts +2 -1
- package/lib/typescript/src/components/AvatarGroup/AvatarGroup.d.ts +2 -1
- package/lib/typescript/src/components/Badge/Badge.d.ts +2 -1
- package/lib/typescript/src/components/Balance/Balance.d.ts +2 -1
- package/lib/typescript/src/components/BenefitCard/BenefitCard.d.ts +93 -0
- package/lib/typescript/src/components/BottomNav/BottomNav.d.ts +2 -1
- package/lib/typescript/src/components/BottomNavItem/BottomNavItem.d.ts +2 -1
- package/lib/typescript/src/components/BrandChip/BrandChip.d.ts +2 -1
- package/lib/typescript/src/components/BubbleChart/BubbleChart.d.ts +2 -1
- package/lib/typescript/src/components/Button/Button.d.ts +2 -1
- package/lib/typescript/src/components/ButtonGroup/ButtonGroup.d.ts +2 -1
- package/lib/typescript/src/components/Card/Card.d.ts +3 -2
- package/lib/typescript/src/components/CardAdvisory/CardAdvisory.d.ts +2 -1
- package/lib/typescript/src/components/CardBankAccount/CardBankAccount.d.ts +2 -1
- package/lib/typescript/src/components/CardCTA/CardCTA.d.ts +2 -1
- package/lib/typescript/src/components/CardFeedback/CardFeedback.d.ts +7 -6
- package/lib/typescript/src/components/CardFinancialCondition/CardFinancialCondition.d.ts +2 -1
- package/lib/typescript/src/components/CardInsight/CardInsight.d.ts +2 -1
- package/lib/typescript/src/components/CardProviderInfo/CardProviderInfo.d.ts +2 -1
- package/lib/typescript/src/components/Carousel/Carousel.d.ts +4 -3
- package/lib/typescript/src/components/CcCard/CcCard.d.ts +137 -0
- package/lib/typescript/src/components/Checkbox/Checkbox.d.ts +5 -3
- package/lib/typescript/src/components/CheckboxGroup/CheckboxGroup.d.ts +2 -1
- package/lib/typescript/src/components/CheckboxItem/CheckboxItem.d.ts +4 -3
- package/lib/typescript/src/components/ChipGroup/ChipGroup.d.ts +2 -1
- package/lib/typescript/src/components/ChipSelect/ChipSelect.d.ts +2 -1
- package/lib/typescript/src/components/CircularProgressBar/CircularProgressBar.d.ts +2 -1
- package/lib/typescript/src/components/CircularProgressBarDoted/CircularProgressBarDoted.d.ts +2 -1
- package/lib/typescript/src/components/CircularRating/CircularRating.d.ts +2 -1
- package/lib/typescript/src/components/ClusterBubble/ClusterBubble.d.ts +2 -1
- package/lib/typescript/src/components/CompareTable/CompareTable.d.ts +88 -0
- package/lib/typescript/src/components/ComparisonBar/ComparisonBar.d.ts +118 -0
- package/lib/typescript/src/components/CoverageBarComparison/CoverageBarComparison.d.ts +3 -2
- package/lib/typescript/src/components/CoverageRing/CoverageRing.d.ts +2 -1
- package/lib/typescript/src/components/DebitCard/DebitCard.d.ts +2 -1
- package/lib/typescript/src/components/Disclaimer/Disclaimer.d.ts +2 -1
- package/lib/typescript/src/components/Divider/Divider.d.ts +2 -1
- package/lib/typescript/src/components/DonutChart/DonutChart.d.ts +4 -3
- package/lib/typescript/src/components/DonutChartSummary/DonutChartSummary.d.ts +3 -2
- package/lib/typescript/src/components/Drawer/Drawer.d.ts +15 -1
- package/lib/typescript/src/components/Dropdown/Dropdown.d.ts +3 -2
- package/lib/typescript/src/components/DropdownInput/DropdownInput.d.ts +22 -2
- package/lib/typescript/src/components/EmptyState/EmptyState.d.ts +2 -1
- package/lib/typescript/src/components/ExpandableCheckbox/ExpandableCheckbox.d.ts +2 -1
- package/lib/typescript/src/components/FilterBar/FilterBar.d.ts +3 -2
- package/lib/typescript/src/components/Form/Form.d.ts +2 -1
- package/lib/typescript/src/components/FormField/FormField.d.ts +4 -3
- package/lib/typescript/src/components/FullscreenModal/FullscreenModal.d.ts +2 -1
- package/lib/typescript/src/components/Gauge/Gauge.d.ts +2 -1
- package/lib/typescript/src/components/HStack/HStack.d.ts +2 -1
- package/lib/typescript/src/components/HoldingsCard/HoldingsCard.d.ts +2 -1
- package/lib/typescript/src/components/Icon/Icon.d.ts +2 -1
- package/lib/typescript/src/components/IconButton/IconButton.d.ts +2 -1
- package/lib/typescript/src/components/IconCapsule/IconCapsule.d.ts +2 -1
- package/lib/typescript/src/components/Image/Image.d.ts +17 -1
- package/lib/typescript/src/components/InputSearch/InputSearch.d.ts +25 -3
- package/lib/typescript/src/components/InstitutionBadge/InstitutionBadge.d.ts +2 -1
- package/lib/typescript/src/components/LazyList/LazyList.d.ts +2 -1
- package/lib/typescript/src/components/LinearMeter/LinearMeter.d.ts +3 -2
- package/lib/typescript/src/components/LinearProgress/LinearProgress.d.ts +2 -1
- package/lib/typescript/src/components/ListGroup/ListGroup.d.ts +2 -1
- package/lib/typescript/src/components/ListItem/ListItem.d.ts +2 -1
- package/lib/typescript/src/components/LottieIntroBlock/LottieIntroBlock.d.ts +2 -1
- package/lib/typescript/src/components/LottiePlayer/LottiePlayer.d.ts +2 -1
- package/lib/typescript/src/components/LottiePlayer/LottiePlayer.web.d.ts +2 -1
- package/lib/typescript/src/components/MediaCard/MediaCard.d.ts +6 -5
- package/lib/typescript/src/components/MerchantProfile/MerchantProfile.d.ts +2 -1
- package/lib/typescript/src/components/MessageField/MessageField.d.ts +2 -1
- package/lib/typescript/src/components/MetricLegendItem/MetricLegendItem.d.ts +2 -1
- package/lib/typescript/src/components/MoneyValue/MoneyValue.d.ts +2 -1
- package/lib/typescript/src/components/MonthlyStatusGrid/MonthlyStatusGrid.d.ts +4 -3
- package/lib/typescript/src/components/NavArrow/NavArrow.d.ts +2 -1
- package/lib/typescript/src/components/NoteInput/NoteInput.d.ts +21 -3
- package/lib/typescript/src/components/Nudge/Nudge.d.ts +2 -1
- package/lib/typescript/src/components/Numpad/Numpad.d.ts +2 -1
- package/lib/typescript/src/components/OTP/OTP.d.ts +3 -2
- package/lib/typescript/src/components/Overlay/Overlay.d.ts +52 -0
- package/lib/typescript/src/components/PageHero/PageHero.d.ts +2 -1
- package/lib/typescript/src/components/PaymentFeedback/PaymentFeedback.d.ts +2 -1
- package/lib/typescript/src/components/PdpCcCard/PdpCcCard.d.ts +84 -0
- package/lib/typescript/src/components/PlanComparisonCard/PlanComparisonCard.d.ts +2 -1
- package/lib/typescript/src/components/Popup/Popup.d.ts +2 -1
- package/lib/typescript/src/components/PortfolioHero/PortfolioHero.d.ts +2 -1
- package/lib/typescript/src/components/PoweredByLabel/PoweredByLabel.d.ts +2 -1
- package/lib/typescript/src/components/ProductLabel/ProductLabel.d.ts +2 -1
- package/lib/typescript/src/components/ProductMerchandisingCard/GlassFill.d.ts +56 -0
- package/lib/typescript/src/components/ProductMerchandisingCard/GlassFill.web.d.ts +27 -0
- package/lib/typescript/src/components/ProductMerchandisingCard/ProductMerchandisingCard.d.ts +81 -0
- package/lib/typescript/src/components/ProductOverview/ProductOverview.d.ts +2 -1
- package/lib/typescript/src/components/ProgressBadge/ProgressBadge.d.ts +2 -1
- package/lib/typescript/src/components/ProjectionMarker/ProjectionMarker.d.ts +82 -0
- package/lib/typescript/src/components/Radio/Radio.d.ts +5 -3
- package/lib/typescript/src/components/RadioButton/RadioButton.d.ts +2 -2
- package/lib/typescript/src/components/RangeTrack/RangeTrack.d.ts +3 -2
- package/lib/typescript/src/components/RechargeCard/RechargeCard.d.ts +2 -1
- package/lib/typescript/src/components/SavingsGoalSummary/SavingsGoalSummary.d.ts +2 -1
- package/lib/typescript/src/components/Screen/Screen.d.ts +2 -1
- package/lib/typescript/src/components/Section/Section.d.ts +3 -2
- package/lib/typescript/src/components/SegmentedControl/SegmentedControl.d.ts +2 -1
- package/lib/typescript/src/components/SegmentedTrack/SegmentedTrack.d.ts +4 -3
- package/lib/typescript/src/components/Slider/Slider.d.ts +99 -0
- package/lib/typescript/src/components/Slot/Slot.d.ts +2 -1
- package/lib/typescript/src/components/Spinner/Spinner.d.ts +2 -1
- package/lib/typescript/src/components/StatGroup/StatGroup.d.ts +2 -1
- package/lib/typescript/src/components/StatItem/StatItem.d.ts +2 -1
- package/lib/typescript/src/components/StatusHero/StatusHero.d.ts +2 -1
- package/lib/typescript/src/components/Stepper/Step.d.ts +2 -1
- package/lib/typescript/src/components/Stepper/StepLabel.d.ts +2 -1
- package/lib/typescript/src/components/Stepper/Stepper.d.ts +2 -1
- package/lib/typescript/src/components/StrengthIndicator/StrengthIndicator.d.ts +2 -1
- package/lib/typescript/src/components/SuggestiveSearch/SuggestiveSearch.d.ts +2 -1
- package/lib/typescript/src/components/SummaryTile/SummaryTile.d.ts +2 -1
- package/lib/typescript/src/components/SupportText/SupportText.d.ts +2 -1
- package/lib/typescript/src/components/SupportText/SupportTextIcon.d.ts +2 -1
- package/lib/typescript/src/components/SwappableAmount/SwappableAmount.d.ts +2 -1
- package/lib/typescript/src/components/Tabs/TabItem.d.ts +2 -1
- package/lib/typescript/src/components/Tabs/Tabs.d.ts +2 -1
- package/lib/typescript/src/components/TestimonialsCard/TestimonialsCard.d.ts +2 -1
- package/lib/typescript/src/components/Text/Text.d.ts +2 -1
- package/lib/typescript/src/components/TextInput/TextInput.d.ts +12 -31
- package/lib/typescript/src/components/TextSegment/TextSegment.d.ts +100 -0
- package/lib/typescript/src/components/ThreadHero/ThreadHero.d.ts +2 -1
- package/lib/typescript/src/components/Title/Title.d.ts +2 -1
- package/lib/typescript/src/components/Toast/Toast.d.ts +2 -1
- package/lib/typescript/src/components/Toast/ToastProvider.d.ts +2 -1
- package/lib/typescript/src/components/Toast/useToast.d.ts +3 -2
- package/lib/typescript/src/components/Toggle/Toggle.d.ts +2 -1
- package/lib/typescript/src/components/Tooltip/Tooltip.d.ts +2 -1
- package/lib/typescript/src/components/TransactionBubble/TransactionBubble.d.ts +2 -1
- package/lib/typescript/src/components/TransactionDetails/TransactionDetails.d.ts +3 -2
- package/lib/typescript/src/components/TransactionStatus/TransactionStatus.d.ts +2 -1
- package/lib/typescript/src/components/UpiHandle/UpiHandle.d.ts +2 -1
- package/lib/typescript/src/components/VStack/VStack.d.ts +2 -1
- package/lib/typescript/src/components/docs/modeControls.d.ts +28 -0
- package/lib/typescript/src/components/index.d.ts +11 -1
- package/lib/typescript/src/design-tokens/JFSThemeProvider.d.ts +4 -3
- package/lib/typescript/src/design-tokens/figma-modes.generated.d.ts +284 -0
- package/lib/typescript/src/design-tokens/index.d.ts +1 -0
- package/lib/typescript/src/icons/registry.d.ts +1 -1
- package/lib/typescript/src/skeleton/Skeleton.d.ts +2 -1
- package/lib/typescript/src/utils/react-utils.d.ts +12 -1
- package/package.json +4 -2
- package/src/components/Accordion/Accordion.tsx +2 -1
- package/src/components/AccordionCheckbox/AccordionCheckbox.tsx +2 -1
- package/src/components/AccountCard/AccountCard.tsx +2 -1
- package/src/components/ActionFooter/ActionFooter.tsx +2 -1
- package/src/components/ActionTile/ActionTile.tsx +2 -1
- package/src/components/AllocationComparisonChart/AllocationComparisonChart.tsx +2 -1
- package/src/components/AmountInput/AmountInput.tsx +9 -6
- package/src/components/AppBar/AppBar.tsx +2 -1
- package/src/components/AreaLineChart/AreaLineChart.tsx +8 -7
- package/src/components/Attached/Attached.tsx +2 -1
- package/src/components/Avatar/Avatar.tsx +3 -2
- package/src/components/AvatarGroup/AvatarGroup.tsx +2 -1
- package/src/components/Badge/Badge.tsx +2 -1
- package/src/components/Balance/Balance.tsx +18 -12
- package/src/components/BenefitCard/BenefitCard.tsx +309 -0
- package/src/components/BottomNav/BottomNav.tsx +2 -1
- package/src/components/BottomNavItem/BottomNavItem.tsx +3 -2
- package/src/components/BrandChip/BrandChip.tsx +3 -2
- package/src/components/BubbleChart/BubbleChart.tsx +2 -1
- package/src/components/Button/Button.tsx +3 -2
- package/src/components/ButtonGroup/ButtonGroup.tsx +2 -1
- package/src/components/Card/Card.tsx +4 -3
- package/src/components/CardAdvisory/CardAdvisory.tsx +3 -2
- package/src/components/CardBankAccount/CardBankAccount.tsx +2 -1
- package/src/components/CardCTA/CardCTA.tsx +3 -2
- package/src/components/CardFeedback/CardFeedback.tsx +11 -10
- package/src/components/CardFinancialCondition/CardFinancialCondition.tsx +3 -2
- package/src/components/CardInsight/CardInsight.tsx +2 -1
- package/src/components/CardProviderInfo/CardProviderInfo.tsx +2 -1
- package/src/components/Carousel/Carousel.tsx +5 -4
- package/src/components/CcCard/CcCard.tsx +598 -0
- package/src/components/Checkbox/Checkbox.tsx +7 -5
- package/src/components/CheckboxGroup/CheckboxGroup.tsx +2 -1
- package/src/components/CheckboxItem/CheckboxItem.tsx +7 -5
- package/src/components/ChipGroup/ChipGroup.tsx +2 -1
- package/src/components/ChipSelect/ChipSelect.tsx +2 -1
- package/src/components/CircularProgressBar/CircularProgressBar.tsx +2 -1
- package/src/components/CircularProgressBarDoted/CircularProgressBarDoted.tsx +2 -1
- package/src/components/CircularRating/CircularRating.tsx +3 -2
- package/src/components/ClusterBubble/ClusterBubble.tsx +2 -1
- package/src/components/CompareTable/CompareTable.tsx +477 -0
- package/src/components/ComparisonBar/ComparisonBar.tsx +356 -0
- package/src/components/CoverageBarComparison/CoverageBarComparison.tsx +3 -2
- package/src/components/CoverageRing/CoverageRing.tsx +2 -1
- package/src/components/DebitCard/DebitCard.tsx +2 -1
- package/src/components/Disclaimer/Disclaimer.tsx +2 -1
- package/src/components/Divider/Divider.tsx +2 -1
- package/src/components/DonutChart/DonutChart.tsx +6 -5
- package/src/components/DonutChartSummary/DonutChartSummary.tsx +3 -2
- package/src/components/Drawer/Drawer.tsx +21 -1
- package/src/components/Dropdown/Dropdown.tsx +4 -3
- package/src/components/DropdownInput/DropdownInput.tsx +60 -7
- package/src/components/EmptyState/EmptyState.tsx +2 -1
- package/src/components/ExpandableCheckbox/ExpandableCheckbox.tsx +2 -1
- package/src/components/FilterBar/FilterBar.tsx +3 -2
- package/src/components/Form/Form.tsx +2 -1
- package/src/components/FormField/FormField.tsx +8 -6
- package/src/components/FullscreenModal/FullscreenModal.tsx +68 -10
- package/src/components/Gauge/Gauge.tsx +2 -1
- package/src/components/HStack/HStack.tsx +2 -1
- package/src/components/HoldingsCard/HoldingsCard.tsx +2 -1
- package/src/components/Icon/Icon.tsx +3 -2
- package/src/components/IconButton/IconButton.tsx +3 -2
- package/src/components/IconCapsule/IconCapsule.tsx +3 -2
- package/src/components/Image/Image.tsx +29 -5
- package/src/components/InputSearch/InputSearch.tsx +11 -7
- package/src/components/InstitutionBadge/InstitutionBadge.tsx +3 -2
- package/src/components/LazyList/LazyList.tsx +2 -1
- package/src/components/LinearMeter/LinearMeter.tsx +3 -2
- package/src/components/LinearProgress/LinearProgress.tsx +2 -1
- package/src/components/ListGroup/ListGroup.tsx +2 -1
- package/src/components/ListItem/ListItem.tsx +3 -2
- package/src/components/LottieIntroBlock/LottieIntroBlock.tsx +2 -1
- package/src/components/LottiePlayer/LottiePlayer.tsx +3 -2
- package/src/components/LottiePlayer/LottiePlayer.web.tsx +3 -2
- package/src/components/LottiePlayer/loadNativeLottieView.tsx +9 -13
- package/src/components/MediaCard/MediaCard.tsx +7 -6
- package/src/components/MerchantProfile/MerchantProfile.tsx +2 -1
- package/src/components/MessageField/MessageField.tsx +3 -2
- package/src/components/MetricLegendItem/MetricLegendItem.tsx +2 -1
- package/src/components/MoneyValue/MoneyValue.tsx +2 -1
- package/src/components/MonthlyStatusGrid/MonthlyStatusGrid.tsx +5 -4
- package/src/components/NavArrow/NavArrow.tsx +3 -2
- package/src/components/NoteInput/NoteInput.tsx +10 -7
- package/src/components/Nudge/Nudge.tsx +3 -2
- package/src/components/Numpad/Numpad.tsx +2 -1
- package/src/components/OTP/OTP.tsx +3 -2
- package/src/components/Overlay/Overlay.tsx +114 -0
- package/src/components/PageHero/PageHero.tsx +2 -1
- package/src/components/PaymentFeedback/PaymentFeedback.tsx +2 -1
- package/src/components/PdpCcCard/PdpCcCard.tsx +356 -0
- package/src/components/PlanComparisonCard/PlanComparisonCard.tsx +2 -1
- package/src/components/Popup/Popup.tsx +2 -1
- package/src/components/PortfolioHero/PortfolioHero.tsx +2 -1
- package/src/components/PoweredByLabel/PoweredByLabel.tsx +2 -1
- package/src/components/ProductLabel/ProductLabel.tsx +2 -1
- package/src/components/ProductMerchandisingCard/GlassFill.tsx +276 -0
- package/src/components/ProductMerchandisingCard/GlassFill.web.tsx +127 -0
- package/src/components/ProductMerchandisingCard/ProductMerchandisingCard.tsx +423 -0
- package/src/components/ProductOverview/ProductOverview.tsx +2 -1
- package/src/components/ProgressBadge/ProgressBadge.tsx +2 -1
- package/src/components/ProjectionMarker/ProjectionMarker.tsx +277 -0
- package/src/components/Radio/Radio.tsx +7 -5
- package/src/components/RangeTrack/RangeTrack.tsx +3 -2
- package/src/components/RechargeCard/RechargeCard.tsx +2 -1
- package/src/components/SavingsGoalSummary/SavingsGoalSummary.tsx +2 -1
- package/src/components/Screen/Screen.tsx +2 -1
- package/src/components/Section/Section.tsx +6 -5
- package/src/components/SegmentedControl/SegmentedControl.tsx +3 -2
- package/src/components/SegmentedTrack/SegmentedTrack.tsx +5 -4
- package/src/components/Slider/Slider.tsx +628 -0
- package/src/components/Slot/Slot.tsx +2 -1
- package/src/components/Spinner/Spinner.tsx +2 -1
- package/src/components/StatGroup/StatGroup.tsx +3 -2
- package/src/components/StatItem/StatItem.tsx +2 -1
- package/src/components/StatusHero/StatusHero.tsx +2 -1
- package/src/components/Stepper/Step.tsx +2 -1
- package/src/components/Stepper/StepLabel.tsx +2 -1
- package/src/components/Stepper/Stepper.tsx +2 -1
- package/src/components/StrengthIndicator/StrengthIndicator.tsx +2 -1
- package/src/components/SuggestiveSearch/SuggestiveSearch.tsx +4 -3
- package/src/components/SummaryTile/SummaryTile.tsx +2 -1
- package/src/components/SupportText/SupportText.tsx +2 -1
- package/src/components/SupportText/SupportTextIcon.tsx +2 -1
- package/src/components/SwappableAmount/SwappableAmount.tsx +2 -1
- package/src/components/Tabs/TabItem.tsx +2 -1
- package/src/components/Tabs/Tabs.tsx +2 -1
- package/src/components/TestimonialsCard/TestimonialsCard.tsx +2 -1
- package/src/components/Text/Text.tsx +2 -1
- package/src/components/TextInput/TextInput.tsx +18 -13
- package/src/components/TextSegment/TextSegment.tsx +166 -0
- package/src/components/ThreadHero/ThreadHero.tsx +2 -1
- package/src/components/Title/Title.tsx +2 -1
- package/src/components/Toast/Toast.tsx +2 -1
- package/src/components/Toast/ToastProvider.tsx +2 -1
- package/src/components/Toast/useToast.ts +3 -2
- package/src/components/Toggle/Toggle.tsx +2 -1
- package/src/components/Tooltip/Tooltip.tsx +3 -2
- package/src/components/TransactionBubble/TransactionBubble.tsx +2 -1
- package/src/components/TransactionDetails/TransactionDetails.tsx +3 -2
- package/src/components/TransactionStatus/TransactionStatus.tsx +3 -2
- package/src/components/UpiHandle/UpiHandle.tsx +3 -2
- package/src/components/VStack/VStack.tsx +2 -1
- package/src/components/docs/modeControls.tsx +122 -0
- package/src/components/index.ts +11 -1
- package/src/design-tokens/Coin Variables-variables-full.json +1 -1
- package/src/design-tokens/JFSThemeProvider.tsx +4 -3
- package/src/design-tokens/figma-modes.generated.ts +425 -0
- package/src/design-tokens/index.ts +1 -0
- package/src/icons/registry.ts +1 -1
- package/src/skeleton/Skeleton.tsx +2 -1
- package/src/utils/react-utils.ts +26 -2
- package/lib/typescript/scripts/extract-component-tokens.d.ts +0 -9
- package/lib/typescript/scripts/generate-component-docs.d.ts +0 -9
- 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?:
|
|
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?:
|
|
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?:
|
|
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?:
|
|
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?:
|
|
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?:
|
|
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?:
|
|
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?:
|
|
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:
|
|
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?:
|
|
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:
|
|
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?:
|
|
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?:
|
|
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?:
|
|
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?:
|
|
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:
|
|
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?:
|
|
254
|
+
modes?: Modes
|
|
254
255
|
/** Style overrides for the popup container. */
|
|
255
256
|
style?: StyleProp<ViewStyle>
|
|
256
257
|
/** Accessibility label for the menu surface. */
|