| 
									
										
										
										
											2020-11-19 13:11:35 -05:00
										 |  |  | // Copyright 2020 Signal Messenger, LLC
 | 
					
						
							|  |  |  | // SPDX-License-Identifier: AGPL-3.0-only
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | import * as React from 'react'; | 
					
						
							|  |  |  | import { select } from '@storybook/addon-knobs'; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2021-10-26 14:15:33 -05:00
										 |  |  | import type { PropsType } from './Tooltip'; | 
					
						
							|  |  |  | import { Tooltip, TooltipPlacement } from './Tooltip'; | 
					
						
							| 
									
										
										
										
											2020-12-04 17:03:01 -06:00
										 |  |  | import { Theme } from '../util/theme'; | 
					
						
							| 
									
										
										
										
											2020-11-19 13:11:35 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | const createProps = (overrideProps: Partial<PropsType> = {}): PropsType => ({ | 
					
						
							|  |  |  |   content: overrideProps.content || 'Hello World', | 
					
						
							|  |  |  |   direction: select('direction', TooltipPlacement, overrideProps.direction), | 
					
						
							|  |  |  |   sticky: overrideProps.sticky, | 
					
						
							| 
									
										
										
										
											2020-11-19 18:38:59 -05:00
										 |  |  |   theme: overrideProps.theme, | 
					
						
							| 
									
										
										
										
											2020-11-19 13:11:35 -05:00
										 |  |  | }); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-06 20:48:02 -04:00
										 |  |  | export default { | 
					
						
							|  |  |  |   title: 'Components/Tooltip', | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2020-11-19 13:11:35 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | const Trigger = ( | 
					
						
							|  |  |  |   <span | 
					
						
							|  |  |  |     style={{ | 
					
						
							|  |  |  |       display: 'inline-block', | 
					
						
							|  |  |  |       marginTop: 200, | 
					
						
							|  |  |  |       marginBottom: 200, | 
					
						
							|  |  |  |       marginLeft: 200, | 
					
						
							|  |  |  |       marginRight: 200, | 
					
						
							|  |  |  |     }} | 
					
						
							|  |  |  |   > | 
					
						
							|  |  |  |     Trigger | 
					
						
							|  |  |  |   </span> | 
					
						
							|  |  |  | ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-06 20:48:02 -04:00
										 |  |  | export const _Top = (): JSX.Element => ( | 
					
						
							| 
									
										
										
										
											2020-11-19 13:11:35 -05:00
										 |  |  |   <Tooltip | 
					
						
							|  |  |  |     {...createProps({ | 
					
						
							|  |  |  |       direction: TooltipPlacement.Top, | 
					
						
							|  |  |  |     })} | 
					
						
							|  |  |  |   > | 
					
						
							|  |  |  |     {Trigger} | 
					
						
							|  |  |  |   </Tooltip> | 
					
						
							| 
									
										
										
										
											2022-06-06 20:48:02 -04:00
										 |  |  | ); | 
					
						
							| 
									
										
										
										
											2020-11-19 13:11:35 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-06 20:48:02 -04:00
										 |  |  | export const _Right = (): JSX.Element => ( | 
					
						
							| 
									
										
										
										
											2020-11-19 13:11:35 -05:00
										 |  |  |   <Tooltip | 
					
						
							|  |  |  |     {...createProps({ | 
					
						
							|  |  |  |       direction: TooltipPlacement.Right, | 
					
						
							|  |  |  |     })} | 
					
						
							|  |  |  |   > | 
					
						
							|  |  |  |     {Trigger} | 
					
						
							|  |  |  |   </Tooltip> | 
					
						
							| 
									
										
										
										
											2022-06-06 20:48:02 -04:00
										 |  |  | ); | 
					
						
							| 
									
										
										
										
											2020-11-19 13:11:35 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-06 20:48:02 -04:00
										 |  |  | export const _Bottom = (): JSX.Element => ( | 
					
						
							| 
									
										
										
										
											2020-11-19 13:11:35 -05:00
										 |  |  |   <Tooltip | 
					
						
							|  |  |  |     {...createProps({ | 
					
						
							|  |  |  |       direction: TooltipPlacement.Bottom, | 
					
						
							|  |  |  |     })} | 
					
						
							|  |  |  |   > | 
					
						
							|  |  |  |     {Trigger} | 
					
						
							|  |  |  |   </Tooltip> | 
					
						
							| 
									
										
										
										
											2022-06-06 20:48:02 -04:00
										 |  |  | ); | 
					
						
							| 
									
										
										
										
											2020-11-19 13:11:35 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-06 20:48:02 -04:00
										 |  |  | export const _Left = (): JSX.Element => ( | 
					
						
							| 
									
										
										
										
											2020-11-19 13:11:35 -05:00
										 |  |  |   <Tooltip | 
					
						
							|  |  |  |     {...createProps({ | 
					
						
							|  |  |  |       direction: TooltipPlacement.Left, | 
					
						
							|  |  |  |     })} | 
					
						
							|  |  |  |   > | 
					
						
							|  |  |  |     {Trigger} | 
					
						
							|  |  |  |   </Tooltip> | 
					
						
							| 
									
										
										
										
											2022-06-06 20:48:02 -04:00
										 |  |  | ); | 
					
						
							| 
									
										
										
										
											2020-11-19 13:11:35 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | export function Sticky(): JSX.Element { | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <Tooltip | 
					
						
							|  |  |  |       {...createProps({ | 
					
						
							|  |  |  |         sticky: true, | 
					
						
							|  |  |  |       })} | 
					
						
							|  |  |  |     > | 
					
						
							|  |  |  |       {Trigger} | 
					
						
							|  |  |  |     </Tooltip> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | } | 
					
						
							| 
									
										
										
										
											2020-11-19 18:38:59 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | export function WithAppliedPopperModifiers(): JSX.Element { | 
					
						
							| 
									
										
										
										
											2021-10-18 17:10:22 -05:00
										 |  |  |   return ( | 
					
						
							|  |  |  |     <Tooltip | 
					
						
							|  |  |  |       {...createProps({ | 
					
						
							|  |  |  |         direction: TooltipPlacement.Bottom, | 
					
						
							|  |  |  |       })} | 
					
						
							|  |  |  |       popperModifiers={[ | 
					
						
							|  |  |  |         { | 
					
						
							|  |  |  |           name: 'offset', | 
					
						
							|  |  |  |           options: { | 
					
						
							|  |  |  |             offset: [80, 80], | 
					
						
							|  |  |  |           }, | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |       ]} | 
					
						
							|  |  |  |     > | 
					
						
							|  |  |  |       {Trigger} | 
					
						
							|  |  |  |     </Tooltip> | 
					
						
							|  |  |  |   ); | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2021-10-18 17:10:22 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-11-17 16:45:19 -08:00
										 |  |  | export function DarkTheme(): JSX.Element { | 
					
						
							|  |  |  |   return ( | 
					
						
							|  |  |  |     <Tooltip | 
					
						
							|  |  |  |       {...createProps({ | 
					
						
							|  |  |  |         sticky: true, | 
					
						
							|  |  |  |         theme: Theme.Dark, | 
					
						
							|  |  |  |       })} | 
					
						
							|  |  |  |     > | 
					
						
							|  |  |  |       {Trigger} | 
					
						
							|  |  |  |     </Tooltip> | 
					
						
							|  |  |  |   ); | 
					
						
							|  |  |  | } |