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
|
@@ -6,6 +6,7 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
6
6
|
exports.EMPTY_MODES = void 0;
|
|
7
7
|
exports.cloneChildrenWithModes = cloneChildrenWithModes;
|
|
8
8
|
exports.flattenChildren = flattenChildren;
|
|
9
|
+
exports.mergeRefs = mergeRefs;
|
|
9
10
|
var _react = _interopRequireDefault(require("react"));
|
|
10
11
|
function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
|
|
11
12
|
/**
|
|
@@ -79,6 +80,27 @@ function cloneChildrenWithModes(children, modes, forcedModes) {
|
|
|
79
80
|
return _react.default.Children.toArray(result);
|
|
80
81
|
}
|
|
81
82
|
|
|
83
|
+
/**
|
|
84
|
+
* Combines several refs (object refs and/or callback refs) into a single
|
|
85
|
+
* callback ref. Useful when a component needs to keep its own internal ref to a
|
|
86
|
+
* node while still honouring a ref forwarded by the consumer.
|
|
87
|
+
*
|
|
88
|
+
* @example
|
|
89
|
+
* const inputRef = useRef<RNTextInput>(null)
|
|
90
|
+
* <RNTextInput ref={mergeRefs(inputRef, forwardedRef)} />
|
|
91
|
+
*/
|
|
92
|
+
function mergeRefs(...refs) {
|
|
93
|
+
return value => {
|
|
94
|
+
refs.forEach(ref => {
|
|
95
|
+
if (typeof ref === 'function') {
|
|
96
|
+
ref(value);
|
|
97
|
+
} else if (ref != null) {
|
|
98
|
+
ref.current = value;
|
|
99
|
+
}
|
|
100
|
+
});
|
|
101
|
+
};
|
|
102
|
+
}
|
|
103
|
+
|
|
82
104
|
/**
|
|
83
105
|
* Flattens React children, extracting them from Fragments.
|
|
84
106
|
* Useful for Group components that need to process individual items (e.g., for layout or styling)
|
|
@@ -6,9 +6,8 @@ import { getVariableByName } from '../../design-tokens/figma-variables-resolver'
|
|
|
6
6
|
import Icon from '../../icons/Icon';
|
|
7
7
|
import { usePressableWebSupport } from '../../utils/web-platform-utils';
|
|
8
8
|
import { EMPTY_MODES, cloneChildrenWithModes } from '../../utils/react-utils';
|
|
9
|
-
|
|
10
|
-
// Enable LayoutAnimation on Android
|
|
11
9
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
10
|
+
// Enable LayoutAnimation on Android
|
|
12
11
|
if (Platform.OS === 'android' && UIManager.setLayoutAnimationEnabledExperimental) {
|
|
13
12
|
UIManager.setLayoutAnimationEnabledExperimental(true);
|
|
14
13
|
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
|
|
3
|
-
import React from 'react';
|
|
3
|
+
import React, { forwardRef } from 'react';
|
|
4
4
|
import { View } from 'react-native';
|
|
5
5
|
import { getVariableByName } from '../../design-tokens/figma-variables-resolver';
|
|
6
6
|
import { useTokens } from '../../design-tokens/JFSThemeProvider';
|
|
@@ -13,12 +13,12 @@ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
|
13
13
|
*
|
|
14
14
|
* @component
|
|
15
15
|
*/
|
|
16
|
-
|
|
16
|
+
const AmountInput = /*#__PURE__*/forwardRef(function AmountInput({
|
|
17
17
|
moneyValueSlot,
|
|
18
18
|
noteInputSlot,
|
|
19
19
|
modes: propModes = EMPTY_MODES,
|
|
20
20
|
style
|
|
21
|
-
}) {
|
|
21
|
+
}, ref) {
|
|
22
22
|
const {
|
|
23
23
|
modes: globalModes
|
|
24
24
|
} = useTokens();
|
|
@@ -72,7 +72,9 @@ export default function AmountInput({
|
|
|
72
72
|
return noteInputSlot;
|
|
73
73
|
};
|
|
74
74
|
return /*#__PURE__*/_jsxs(View, {
|
|
75
|
+
ref: ref,
|
|
75
76
|
style: containerStyle,
|
|
76
77
|
children: [renderMoneyValueSlot(), renderNoteInputSlot()]
|
|
77
78
|
});
|
|
78
|
-
}
|
|
79
|
+
});
|
|
80
|
+
export default AmountInput;
|
|
@@ -4,8 +4,15 @@ import React from 'react';
|
|
|
4
4
|
import { View, Text } from 'react-native';
|
|
5
5
|
import { getVariableByName } from '../../design-tokens/figma-variables-resolver';
|
|
6
6
|
import MoneyValue from '../MoneyValue/MoneyValue';
|
|
7
|
-
import { EMPTY_MODES } from '../../utils/react-utils';
|
|
7
|
+
import { EMPTY_MODES, cloneChildrenWithModes } from '../../utils/react-utils';
|
|
8
8
|
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
9
|
+
// The Balance design renders its money value at the 36 px / 900-weight scale.
|
|
10
|
+
// The `moneyValue/*` tokens alias into the `Context3` collection, where the
|
|
11
|
+
// `Balance & Cards` mode supplies those larger values. Applied *before* the
|
|
12
|
+
// caller's `modes` so any consumer can still override individual keys.
|
|
13
|
+
const DEFAULT_MONEY_VALUE_MODES = {
|
|
14
|
+
Context3: 'Balance & Cards'
|
|
15
|
+
};
|
|
9
16
|
/**
|
|
10
17
|
* Balance component that displays a title and a monetary value.
|
|
11
18
|
*
|
|
@@ -29,7 +36,7 @@ function Balance({
|
|
|
29
36
|
// Title styles
|
|
30
37
|
const titleColor = getVariableByName('balance/title/foreground', modes) ?? '#0c0d10';
|
|
31
38
|
const titleFontSize = getVariableByName('balance/title/fontSize', modes) ?? 14;
|
|
32
|
-
const titleFontFamily = getVariableByName('balance/title/fontFamily', modes) ?? '
|
|
39
|
+
const titleFontFamily = getVariableByName('balance/title/fontFamily', modes) ?? 'JioType Var';
|
|
33
40
|
const titleLineHeight = getVariableByName('balance/title/lineHeight', modes) ?? 18;
|
|
34
41
|
const titleFontWeightValue = getVariableByName('balance/title/fontWeight', modes) ?? 500;
|
|
35
42
|
const titleFontWeight = typeof titleFontWeightValue === 'number' ? titleFontWeightValue.toString() : titleFontWeightValue;
|
|
@@ -46,15 +53,13 @@ function Balance({
|
|
|
46
53
|
fontWeight: titleFontWeight
|
|
47
54
|
};
|
|
48
55
|
|
|
49
|
-
//
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
return child;
|
|
57
|
-
});
|
|
56
|
+
// The money value renders at the Balance & Cards scale. Merge the default
|
|
57
|
+
// context mode first so the caller's `modes` can still override it, and
|
|
58
|
+
// force that context onto any slotted children so custom money values match.
|
|
59
|
+
const moneyValueModes = {
|
|
60
|
+
...DEFAULT_MONEY_VALUE_MODES,
|
|
61
|
+
...modes
|
|
62
|
+
};
|
|
58
63
|
return /*#__PURE__*/_jsxs(View, {
|
|
59
64
|
style: [containerStyle, style],
|
|
60
65
|
"data-node-id": "1986:6203",
|
|
@@ -62,10 +67,10 @@ function Balance({
|
|
|
62
67
|
style: titleStyle,
|
|
63
68
|
"data-node-id": "1986:2613",
|
|
64
69
|
children: title
|
|
65
|
-
}), children ?
|
|
70
|
+
}), children ? cloneChildrenWithModes(children, modes, DEFAULT_MONEY_VALUE_MODES) : /*#__PURE__*/_jsx(MoneyValue, {
|
|
66
71
|
value: amount,
|
|
67
72
|
currency: currency,
|
|
68
|
-
modes:
|
|
73
|
+
modes: moneyValueModes
|
|
69
74
|
})]
|
|
70
75
|
});
|
|
71
76
|
}
|
|
@@ -0,0 +1,225 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
import React, { useMemo } from 'react';
|
|
4
|
+
import { View, Text as RNText, Pressable, StyleSheet } from 'react-native';
|
|
5
|
+
import { getVariableByName } from '../../design-tokens/figma-variables-resolver';
|
|
6
|
+
import { EMPTY_MODES, cloneChildrenWithModes } from '../../utils/react-utils';
|
|
7
|
+
import Icon from '../Icon/Icon';
|
|
8
|
+
import Text from '../Text/Text';
|
|
9
|
+
import ListItem from '../ListItem/ListItem';
|
|
10
|
+
import Divider from '../Divider/Divider';
|
|
11
|
+
import Button from '../Button/Button';
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* A single benefit row rendered with the shared `ListItem` primitive: a
|
|
15
|
+
* leading icon, a title and an optional right-aligned trailing value.
|
|
16
|
+
*/
|
|
17
|
+
import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
|
|
18
|
+
/**
|
|
19
|
+
* BenefitCard — Figma node 5352:1077 ("Benefit Card").
|
|
20
|
+
*
|
|
21
|
+
* A white, rounded card that summarises the rewards a user will earn. It is
|
|
22
|
+
* composed entirely from the shared design-system primitives so it stays in
|
|
23
|
+
* sync with the rest of the library:
|
|
24
|
+
*
|
|
25
|
+
* - **Header** — a section title + a single highlighted {@link ListItem}
|
|
26
|
+
* (leading `Icon`, title, right-aligned trailing value) followed by a
|
|
27
|
+
* `Divider`.
|
|
28
|
+
* - **Body** — a section title + a column of benefit {@link ListItem}s. The
|
|
29
|
+
* list is a real slot: pass `children` to fully control it, or `items` for
|
|
30
|
+
* the declarative path.
|
|
31
|
+
* - **CTA** — a small {@link Button} (Figma `Button / Size = S`).
|
|
32
|
+
*
|
|
33
|
+
* The list rows resolve through the `List Item Style: Minimal` mode (12px /
|
|
34
|
+
* regular title, 4px gap, no padding) and the leading icons use the
|
|
35
|
+
* `AppearanceBrand: Secondary` brand color, exactly matching the design. All
|
|
36
|
+
* three defaults can be overridden via `modes`.
|
|
37
|
+
*/
|
|
38
|
+
function BenefitCard({
|
|
39
|
+
headerTitle = 'You will earn',
|
|
40
|
+
headerItem,
|
|
41
|
+
showHeader = true,
|
|
42
|
+
bodyTitle = 'Upgrade to JioFinance+ and earn more',
|
|
43
|
+
items,
|
|
44
|
+
children,
|
|
45
|
+
buttonLabel = 'Upgrade',
|
|
46
|
+
onButtonPress,
|
|
47
|
+
button,
|
|
48
|
+
showButton = true,
|
|
49
|
+
onPress,
|
|
50
|
+
width = 344,
|
|
51
|
+
modes = EMPTY_MODES,
|
|
52
|
+
style,
|
|
53
|
+
accessibilityLabel
|
|
54
|
+
}) {
|
|
55
|
+
const tokens = useMemo(() => resolveTokens(modes), [modes]);
|
|
56
|
+
|
|
57
|
+
// Sub-component modes. Consumer-supplied `modes` always win via spread order.
|
|
58
|
+
const listItemModes = useMemo(() => ({
|
|
59
|
+
'List Item Style': 'Minimal',
|
|
60
|
+
...modes
|
|
61
|
+
}), [modes]);
|
|
62
|
+
const iconModes = useMemo(() => ({
|
|
63
|
+
AppearanceBrand: 'Secondary',
|
|
64
|
+
...modes
|
|
65
|
+
}), [modes]);
|
|
66
|
+
const trailingTextModes = useMemo(() => ({
|
|
67
|
+
'Text Sizes': 'Small',
|
|
68
|
+
Weight: 'Regular',
|
|
69
|
+
...modes
|
|
70
|
+
}), [modes]);
|
|
71
|
+
const ctaModes = useMemo(() => ({
|
|
72
|
+
'Button / Size': 'S',
|
|
73
|
+
...modes
|
|
74
|
+
}), [modes]);
|
|
75
|
+
const renderItem = (item, key) => {
|
|
76
|
+
const leading = item.leading ?? (item.icon != null ? /*#__PURE__*/_jsx(Icon, {
|
|
77
|
+
iconName: item.icon,
|
|
78
|
+
color: item.iconColor,
|
|
79
|
+
modes: iconModes
|
|
80
|
+
}) : null);
|
|
81
|
+
const trailing = item.trailing ?? (item.trailingText != null ? /*#__PURE__*/_jsx(Text, {
|
|
82
|
+
modes: trailingTextModes,
|
|
83
|
+
children: item.trailingText
|
|
84
|
+
}) : undefined);
|
|
85
|
+
return /*#__PURE__*/_jsx(ListItem, {
|
|
86
|
+
layout: "Horizontal",
|
|
87
|
+
navArrow: false,
|
|
88
|
+
showSupportText: false,
|
|
89
|
+
title: item.title,
|
|
90
|
+
leading: leading,
|
|
91
|
+
trailing: trailing,
|
|
92
|
+
onPress: item.onPress,
|
|
93
|
+
modes: listItemModes
|
|
94
|
+
}, key);
|
|
95
|
+
};
|
|
96
|
+
const headerNode = showHeader && (headerTitle != null || headerItem != null) ? /*#__PURE__*/_jsxs(View, {
|
|
97
|
+
style: styles.section,
|
|
98
|
+
children: [/*#__PURE__*/_jsxs(View, {
|
|
99
|
+
style: styles.cardHeader,
|
|
100
|
+
children: [headerTitle != null ? /*#__PURE__*/_jsx(RNText, {
|
|
101
|
+
style: tokens.title,
|
|
102
|
+
children: headerTitle
|
|
103
|
+
}) : null, headerItem != null ? renderItem(headerItem, 'header-item') : null]
|
|
104
|
+
}), /*#__PURE__*/_jsx(Divider, {
|
|
105
|
+
modes: modes
|
|
106
|
+
})]
|
|
107
|
+
}) : null;
|
|
108
|
+
const bodyList = children ? cloneChildrenWithModes(children, listItemModes) : (items ?? DEFAULT_ITEMS).map((item, index) => renderItem(item, index));
|
|
109
|
+
const ctaNode = button ?? /*#__PURE__*/_jsx(Button, {
|
|
110
|
+
label: buttonLabel,
|
|
111
|
+
modes: ctaModes,
|
|
112
|
+
onPress: onButtonPress
|
|
113
|
+
});
|
|
114
|
+
const containerStyle = useMemo(() => ({
|
|
115
|
+
...tokens.container,
|
|
116
|
+
width
|
|
117
|
+
}), [tokens.container, width]);
|
|
118
|
+
const content = /*#__PURE__*/_jsxs(_Fragment, {
|
|
119
|
+
children: [headerNode, /*#__PURE__*/_jsxs(View, {
|
|
120
|
+
style: tokens.body,
|
|
121
|
+
children: [bodyTitle != null ? /*#__PURE__*/_jsx(RNText, {
|
|
122
|
+
style: tokens.title,
|
|
123
|
+
children: bodyTitle
|
|
124
|
+
}) : null, /*#__PURE__*/_jsx(View, {
|
|
125
|
+
style: tokens.listWrap,
|
|
126
|
+
children: bodyList
|
|
127
|
+
})]
|
|
128
|
+
}), showButton ? ctaNode : null]
|
|
129
|
+
});
|
|
130
|
+
if (onPress) {
|
|
131
|
+
return /*#__PURE__*/_jsx(Pressable, {
|
|
132
|
+
style: ({
|
|
133
|
+
pressed
|
|
134
|
+
}) => [containerStyle, pressed ? styles.pressed : null, style],
|
|
135
|
+
accessibilityRole: "button",
|
|
136
|
+
accessibilityLabel: accessibilityLabel ?? headerTitle ?? bodyTitle,
|
|
137
|
+
onPress: onPress,
|
|
138
|
+
children: content
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
return /*#__PURE__*/_jsx(View, {
|
|
142
|
+
style: [containerStyle, style],
|
|
143
|
+
accessibilityLabel: accessibilityLabel,
|
|
144
|
+
children: content
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
// ---------------------------------------------------------------------------
|
|
149
|
+
// Tokens / static styles
|
|
150
|
+
// ---------------------------------------------------------------------------
|
|
151
|
+
|
|
152
|
+
// The "card header" inner gap (title -> highlighted item) is a fixed 4px in
|
|
153
|
+
// the Figma node and has no dedicated token.
|
|
154
|
+
const CARD_HEADER_GAP = 4;
|
|
155
|
+
function asNum(raw, fallback) {
|
|
156
|
+
const n = typeof raw === 'number' ? raw : parseFloat(raw);
|
|
157
|
+
return Number.isFinite(n) ? n : fallback;
|
|
158
|
+
}
|
|
159
|
+
function asStr(raw, fallback) {
|
|
160
|
+
return raw != null ? String(raw) : fallback;
|
|
161
|
+
}
|
|
162
|
+
function resolveTokens(modes) {
|
|
163
|
+
// NOTE: token names are passed as string literals DIRECTLY to
|
|
164
|
+
// getVariableByName so the `extract-component-tokens` script can statically
|
|
165
|
+
// collect them for the generated docs. Do not refactor these into a helper
|
|
166
|
+
// that receives the name as a variable.
|
|
167
|
+
const background = asStr(getVariableByName('benefitCard/background', modes), '#ffffff');
|
|
168
|
+
const paddingHorizontal = asNum(getVariableByName('benefitCard/padding/horizontal', modes), 12);
|
|
169
|
+
const paddingVertical = asNum(getVariableByName('benefitCard/padding/vertical', modes), 12);
|
|
170
|
+
const radius = asNum(getVariableByName('benefitCard/radius', modes), 12);
|
|
171
|
+
const gap = asNum(getVariableByName('benefitCard/gap', modes), 8);
|
|
172
|
+
const titleColor = asStr(getVariableByName('benefitCard/title/foreground', modes), '#000000');
|
|
173
|
+
const titleSize = asNum(getVariableByName('benefitCard/title/fontsize', modes), 14);
|
|
174
|
+
const titleFamily = asStr(getVariableByName('benefitCard/title/fontFamily', modes), 'JioType Var');
|
|
175
|
+
const titleWeight = asStr(getVariableByName('benefitCard/title/fontWeight', modes), '500');
|
|
176
|
+
return {
|
|
177
|
+
container: {
|
|
178
|
+
backgroundColor: background,
|
|
179
|
+
paddingHorizontal,
|
|
180
|
+
paddingVertical,
|
|
181
|
+
borderRadius: radius,
|
|
182
|
+
gap,
|
|
183
|
+
flexDirection: 'column',
|
|
184
|
+
alignItems: 'flex-start'
|
|
185
|
+
},
|
|
186
|
+
body: {
|
|
187
|
+
alignSelf: 'stretch',
|
|
188
|
+
gap
|
|
189
|
+
},
|
|
190
|
+
listWrap: {
|
|
191
|
+
alignSelf: 'stretch',
|
|
192
|
+
gap
|
|
193
|
+
},
|
|
194
|
+
title: {
|
|
195
|
+
color: titleColor,
|
|
196
|
+
fontSize: titleSize,
|
|
197
|
+
fontFamily: titleFamily,
|
|
198
|
+
fontWeight: titleWeight,
|
|
199
|
+
lineHeight: 20,
|
|
200
|
+
letterSpacing: -0.5,
|
|
201
|
+
includeFontPadding: false
|
|
202
|
+
}
|
|
203
|
+
};
|
|
204
|
+
}
|
|
205
|
+
const DEFAULT_ITEMS = [{
|
|
206
|
+
icon: 'ic_card',
|
|
207
|
+
title: 'Up to ₹5000 cashback'
|
|
208
|
+
}, {
|
|
209
|
+
icon: 'ic_card',
|
|
210
|
+
title: '25% extra JioPoints'
|
|
211
|
+
}];
|
|
212
|
+
const styles = StyleSheet.create({
|
|
213
|
+
section: {
|
|
214
|
+
alignSelf: 'stretch',
|
|
215
|
+
gap: 8
|
|
216
|
+
},
|
|
217
|
+
cardHeader: {
|
|
218
|
+
alignSelf: 'stretch',
|
|
219
|
+
gap: CARD_HEADER_GAP
|
|
220
|
+
},
|
|
221
|
+
pressed: {
|
|
222
|
+
opacity: 0.92
|
|
223
|
+
}
|
|
224
|
+
});
|
|
225
|
+
export default BenefitCard;
|
|
@@ -4,13 +4,12 @@ import React, { createContext, useContext, isValidElement, cloneElement } from '
|
|
|
4
4
|
import { View, Text } from 'react-native';
|
|
5
5
|
import { getVariableByName } from '../../design-tokens/figma-variables-resolver';
|
|
6
6
|
import { EMPTY_MODES } from '../../utils/react-utils';
|
|
7
|
-
|
|
7
|
+
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
8
8
|
/**
|
|
9
9
|
* Context to share 'modes' with child components like Card.Title and Card.SupportText.
|
|
10
10
|
* This ensures that nested components can resolve their tokens correctly without
|
|
11
11
|
* needing explicit mode prop passing for every child.
|
|
12
12
|
*/
|
|
13
|
-
import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
|
|
14
13
|
const CardContext = /*#__PURE__*/createContext({});
|
|
15
14
|
/**
|
|
16
15
|
* Card component implementation from Figma node 765:6186.
|
|
@@ -4,11 +4,10 @@ import React, { createContext, useContext, isValidElement, cloneElement } from '
|
|
|
4
4
|
import { View, Text } from 'react-native';
|
|
5
5
|
import { getVariableByName } from '../../design-tokens/figma-variables-resolver';
|
|
6
6
|
import IconComponent from '../../icons/Icon';
|
|
7
|
-
|
|
7
|
+
import { jsx as _jsx } from "react/jsx-runtime";
|
|
8
8
|
/**
|
|
9
9
|
* Context to share 'modes' with child components.
|
|
10
10
|
*/
|
|
11
|
-
import { jsx as _jsx } from "react/jsx-runtime";
|
|
12
11
|
const CardFeedbackContext = /*#__PURE__*/createContext({});
|
|
13
12
|
/**
|
|
14
13
|
* CardFeedback component from Figma node 1280:4481.
|