Tour

Introduce people to new features using multi-step tours.

Onboarding tours can be used to introduce people that are new to your app or when introducing new features to your customers. It supports the build BenefitsModal and TourDialog components, as well as any other disclosure component that supports isOpen and onClose props.

Import

  • Tour: Context provider that manages the tour state.
  • TourSpotlight: Spotlight focuses people to a specific UI element.
import { Tour, TourSpotlight } from '@saas-ui-pro/react'

Usage

Basic usage

Each tour step should have a data-target attribute with a CSS selector of the component that should be highlighted. Any component that accepts isOpen and onClose can be part of a tour.

import {
Button,
ButtonGroup,
Stack,
Text,
useDisclosure,
} from '@chakra-ui/react'
import {
Tour,
TourDialog,
TourDialogActions,
TourDialogBody,
TourDialogCloseButton,
TourDialogFooter,
TourDialogHeader,
TourNextButton,
TourSpotlight,
} from '@saas-ui-pro/react'
import { FiUsers } from 'react-icons/fi'
export default function Basic() {
const { isOpen, onOpen, onClose } = useDisclosure()
return (
<>
<Stack spacing="8" alignItems="center">
<ButtonGroup>
<Button leftIcon={<FiUsers />} data-tour="add-users">
Add user
</Button>
</ButtonGroup>
<Button onClick={onOpen} variant="primary">
Start example tour
</Button>
</Stack>
<Tour isActive={isOpen} onComplete={onClose}>
<TourDialog data-target="[data-tour=add-users]">
<TourDialogCloseButton />
<TourDialogHeader>Check out this new feature</TourDialogHeader>
<TourDialogBody>
The tour allows you to highlight important new features.
</TourDialogBody>
<TourDialogFooter>
<TourDialogActions>
<TourNextButton>OK</TourNextButton>
</TourDialogActions>
</TourDialogFooter>
</TourDialog>
<TourSpotlight />
</Tour>
</>
)
}
import {
Button,
IconButton,
ButtonGroup,
Stack,
Text,
useDisclosure,
} from '@chakra-ui/react'
import {
Tour,
TourDialog,
TourDialogActions,
TourDialogBody,
TourDialogCloseButton,
TourDialogFooter,
TourDialogHeader,
TourNextButton,
TourSpotlight,
} from '@saas-ui-pro/react'
import { FiUsers, FiTag, FiLock } from 'react-icons/fi'
export default function Basic() {
const { isOpen, onOpen, onClose } = useDisclosure()
return (
<>
<Stack spacing="8" alignItems="center">
<ButtonGroup>
<Button leftIcon={<FiUsers />} data-tour="add-users2">
Add user
</Button>
<IconButton
icon={<FiTag />}
aria-label="Tag users"
data-tour="tag-users"
/>
<IconButton
icon={<FiLock />}
aria-label="Lock users"
data-tour="lock-users"
/>
</ButtonGroup>
<Button onClick={onOpen} variant="primary">
Start example tour
</Button>
</Stack>
<Tour isActive={isOpen} onComplete={onClose}>
<TourDialog data-target="[data-tour=add-users2]">
<TourDialogCloseButton />
<TourDialogHeader>Check out this new feature</TourDialogHeader>
<TourDialogBody>Start the tour to see how it works.</TourDialogBody>
<TourDialogFooter>
<Text fontSize="sm">Step 1 of 3</Text>
<TourDialogActions>
<TourDismissButton />
<TourNextButton>Start</TourNextButton>
</TourDialogActions>
</TourDialogFooter>
</TourDialog>
<TourDialog data-target="[data-tour=tag-users]">
<TourDialogCloseButton />
<TourDialogHeader>Step 2</TourDialogHeader>
<TourDialogBody>Tour step 2.</TourDialogBody>
<TourDialogFooter>
<Text fontSize="sm">Step 2 of 3</Text>
<TourDialogActions>
<TourNextButton />
</TourDialogActions>
</TourDialogFooter>
</TourDialog>
<TourDialog data-target="[data-tour=lock-users]">
<TourDialogCloseButton />
<TourDialogHeader>Step 3</TourDialogHeader>
<TourDialogBody>Tour step 3.</TourDialogBody>
<TourDialogFooter>
<Text fontSize="sm">Step 3 of 3</Text>
<TourDialogActions>
<TourNextButton>Finish</TourNextButton>
</TourDialogActions>
</TourDialogFooter>
</TourDialog>
<TourSpotlight />
</Tour>
</>
)
}

Was this helpful?