Emails
1 month ago
EngagementChart
1 month ago
MediaHub
1 month ago
Onboarding
1 month ago
Popup
1 month ago
Skeletons
1 week ago
WhatsNew
1 month ago
charts
1 month ago
test
1 month ago
AdminMenuSync.js
1 month ago
ChartEmptyState.js
1 month ago
ChooseDate.js
1 month ago
ColorPicker.js
1 month ago
ExtendPlugins.js
1 month ago
Filters.js
1 month ago
Link.js
1 month ago
Navbar.js
1 week ago
NoFound.js
1 month ago
PageHeader.js
1 month ago
PluginRecommendations.js
1 month ago
PostScheduleField.js
1 month ago
PrestoPlayerIcon.js
1 month ago
ProGateOverlay.js
1 month ago
QuickAccess.js
1 month ago
RankedTable.js
1 month ago
StatCard.js
1 month ago
TopMedia.js
1 month ago
TopPerformingMedia.js
1 month ago
TopUsers.js
1 month ago
TruncatedTitle.js
1 month ago
UpgradeNotice.js
1 month ago
UpgradeToPro.js
1 month ago
VideoModal.js
1 month ago
WelcomeBanner.js
1 month ago
Link.js
26 lines
| 1 | import { Children, cloneElement, isValidElement } from "react"; |
| 2 | import { Text } from "@bsf/force-ui"; |
| 3 | import useLink from "../hooks/useLink"; |
| 4 | |
| 5 | const Link = ({ params, children, ...props }) => { |
| 6 | const { href, onClick } = useLink(params); |
| 7 | |
| 8 | // If a single valid React element is provided, clone it with routing props |
| 9 | if (isValidElement(children) && Children.count(children) === 1) { |
| 10 | return cloneElement(children, { |
| 11 | href, |
| 12 | onClick, |
| 13 | ...props, |
| 14 | }); |
| 15 | } |
| 16 | |
| 17 | // Default fallback: wrap in Force UI Text as anchor |
| 18 | return ( |
| 19 | <Text as="a" href={href} onClick={onClick} className="no-underline hover:no-underline" {...props}> |
| 20 | {children} |
| 21 | </Text> |
| 22 | ); |
| 23 | }; |
| 24 | |
| 25 | export default Link; |
| 26 |