UNPKG

@neo4j-ndl/react

Version:

React implementation of Neo4j Design System

96 lines 4.38 kB
/** * * Copyright (c) "Neo4j" * Neo4j Sweden AB [http://neo4j.com] * * This file is part of Neo4j. * * Neo4j is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ import type React from 'react'; import { type CommonProps, type HtmlAttributes, type PolymorphicCommonProps } from '../_common/types'; type BreadcrumbsProps = { /** Content to be rendered. Should only be `Breadcrumbs.Item`. */ children?: React.ReactNode; /** Additional classnames. */ shouldWrap?: boolean; }; type BreadcrumbsItemContextType = { isInBreadcrumbsItem: boolean; }; export declare const useBreadcrumbsItemContext: () => BreadcrumbsItemContextType; type BreadcrumbsItemProps = { /** Content to be rendered. Should be either `Breadcrumbs.Link`, `Breadcrumbs.Button` or `Breadcrumbs.SelectButton`. */ children?: React.ReactNode; }; type InteractiveBreadcrumbProps = { /** Content to be rendered. */ children?: React.ReactNode; } & ({ as: 'button'; /** * Event handler for when the button is clicked. Only applicable if `as` is `'button'`. */ onClick?: (event: React.MouseEvent<HTMLButtonElement, MouseEvent>) => void; } | { as: 'a'; /** * The href of the link. Only applicable if `as` is `'a'`. */ href: HtmlAttributes<'a'>['href']; /** * The target of the link. Only applicable if `as` is `'a'`. */ target?: HtmlAttributes<'a'>['target']; } | { /** * What HTML element to render the root element as. */ as?: React.ElementType; }); type BreadcrumbsButtonProps = InteractiveBreadcrumbProps & { /** Leading element to be rendered. */ leadingElement?: React.ReactNode; /** Trailing element to be rendered. */ trailingElement?: React.ReactNode; }; type BreadcrumbsSelectButtonProps = { /** Event handler for when the button is clicked. Should be used to open a `Menu`. */ onClick?: (event: React.MouseEvent<HTMLButtonElement>) => void; /** Aria label needed for accessibility. */ ariaLabel: string; /** Content to be rendered. */ children?: React.ReactNode; /** Additional classnames. */ className?: string; /** Additional css styling. */ style?: React.CSSProperties; /** HTML attributes. */ htmlAttributes?: HtmlAttributes<'button'>; }; type BreadcrumbsLinkProps = InteractiveBreadcrumbProps & { /** * Whether the link is the current item. Use `'page'` if it indicates the current page and `'step'` for steps (in a multi-step wizard for example). * @see https://developer.mozilla.org/en-US/docs/Web/Accessibility/ARIA/Attributes/aria-current */ ariaCurrent?: React.AriaAttributes['aria-current']; }; declare const Breadcrumbs: (({ children, className, htmlAttributes, style, ref, shouldWrap, ...restProps }: CommonProps<"nav", BreadcrumbsProps>) => import("react/jsx-runtime").JSX.Element) & { Button: <T extends React.ElementType = "button">({ children, as, className, style, htmlAttributes, ref, leadingElement, trailingElement, ...restProps }: PolymorphicCommonProps<T, BreadcrumbsButtonProps>) => import("react/jsx-runtime").JSX.Element; Item: ({ children, className, style, htmlAttributes, ref, ...restProps }: CommonProps<"li", BreadcrumbsItemProps>) => import("react/jsx-runtime").JSX.Element; Link: <T extends React.ElementType = "a">({ children, as, className, style, htmlAttributes, ariaCurrent, ref, ...restProps }: PolymorphicCommonProps<T, BreadcrumbsLinkProps>) => import("react/jsx-runtime").JSX.Element; SelectButton: ({ onClick, children, className, style, htmlAttributes, ariaLabel, ref, ...restProps }: CommonProps<"button", BreadcrumbsSelectButtonProps>) => import("react/jsx-runtime").JSX.Element; }; export { Breadcrumbs }; //# sourceMappingURL=Breadcrumbs.d.ts.map