diff --git a/packages/components/src/tabs/stories/index.story.tsx b/packages/components/src/tabs/stories/index.story.tsx index 5b2fd621bbb436..a3c3868055a13f 100644 --- a/packages/components/src/tabs/stories/index.story.tsx +++ b/packages/components/src/tabs/stories/index.story.tsx @@ -7,7 +7,12 @@ import type { Meta, StoryFn } from '@storybook/react'; * WordPress dependencies */ import { wordpress, more, link } from '@wordpress/icons'; -import { useState } from '@wordpress/element'; +import { + useState, + forwardRef, + createContext, + useContext, +} from '@wordpress/element'; /** * Internal dependencies @@ -492,3 +497,125 @@ const TabGetsRemovedTemplate: StoryFn< typeof Tabs > = ( props ) => { ); }; export const TabGetsRemoved = TabGetsRemovedTemplate.bind( {} ); + +const WITH_LINKS_PAGES = [ + { + title: 'Page 1', + url: 'page1', + }, + { + title: 'Page 2', + url: 'page2', + }, + { + title: 'Page 3', + url: 'page3', + }, +]; + +const SimpleRouterContext = createContext< { + currentPath: string | undefined; + goTo: ( path: string | undefined ) => void; +} >( { + currentPath: undefined, + goTo: () => {}, +} ); + +const SimpleRouter = ( { + children, + initialRoute = '/', +}: { + children: React.ReactNode; + initialRoute?: string; +} ) => { + const [ currentPath, setCurrentPath ] = useState< string | undefined >( + initialRoute + ); + + const goTo = ( path: string | undefined ) => { + setCurrentPath( path ); + }; + + return ( + + { children } + + ); +}; + +const SimpleRouterLink = forwardRef( + ( + { + to, + children, + onClick, + style, + ...restProps + }: { + to: string; + children?: React.ReactNode; + } & React.HTMLProps< HTMLAnchorElement >, + ref: React.ForwardedRef< HTMLAnchorElement > + ) => { + const { goTo } = useContext( SimpleRouterContext ); + + return ( + { + event.preventDefault(); + goTo( to ); + onClick?.( event ); + } } + style={ { + ...style, + textDecoration: 'none', + } } + { ...restProps } + > + { children } + + ); + } +); + +const WithLinksTabs = ( props: React.ComponentProps< typeof Tabs > ) => { + const { currentPath, goTo } = useContext( SimpleRouterContext ); + + return ( + { + goTo( newTabId ?? undefined ); + } } + { ...props } + > + + { WITH_LINKS_PAGES.map( ( page ) => ( + } + > + { page.title } + + ) ) } + + { WITH_LINKS_PAGES.map( ( page ) => ( + + Selected tab: { page.title } + + ) ) } + + ); +}; + +const WithLinksTemplate: StoryFn< typeof Tabs > = ( props ) => { + return ( + + + + ); +}; +export const WithLinks = WithLinksTemplate.bind( {} );
Selected tab: { page.title }